#-*-coding utf-8-*- # Общественное достояние, 2023, Алексей Безбородов (Alexei Bezborodov) from enum import Enum from enum import auto # Тип поля в таблице class TableFieldType(Enum): INT = auto() STR = auto() ENUM = auto() def InitTableType(a_TableFieldType): types = { TableFieldType.INT: 'INTEGER', TableFieldType.STR: 'TEXT', TableFieldType.ENUM: 'TEXT', } return types.get(a_TableFieldType, None) # Предназначение поля в таблице class TableFieldDestiny(Enum): KEY = auto() NAME = auto() DESC = auto() PHOTO = auto() ACCESS = auto() DEFAULT_ACCESS = auto() CREATE_DATE = auto() PARENT_ID = auto() STATUS = auto() ADDRESS = auto() OTHER = auto() class TableField: def __init__(self, a_Name, a_Destiny : TableFieldDestiny, a_Type : TableFieldType, a_Enum = None): self.m_Name = a_Name self.m_Destiny = a_Destiny self.m_Type = a_Type self.m_Enum = a_Enum class Table: def __init__(self, a_TableName, a_Fields : [TableField], a_UniqueFields = None): self.m_TableName = a_TableName self.m_Fields = a_Fields self.m_UniqueFields = a_UniqueFields def GetName(self): return self.m_TableName def GetFields(self): return self.m_Fields def GetFieldsCount(self): return len(self.m_Fields) def GetFieldByDestiny(self, a_Destiny): for f in self.m_Fields: if f.m_Destiny == a_Destiny: return f return None def GetFieldNameByDestiny(self, a_Destiny): f = self.GetFieldByDestiny(a_Destiny) if f: return f.m_Name return None def GetFieldIDByDestiny(self, a_Destiny): for i in range(len(self.m_Fields)): f = self.m_Fields[i] if f.m_Destiny == a_Destiny: return i return None def GetInitTableRequest(self): request = f'CREATE TABLE IF NOT EXISTS {self.GetName()}(' items = [] for f in self.m_Fields: item = f.m_Name + ' ' + str(InitTableType(f.m_Type)) if f.m_Destiny == TableFieldDestiny.KEY: item += ' PRIMARY KEY' items += [item] if self.m_UniqueFields: for u in self.m_UniqueFields: fields = [] for f in u: fields += [f.m_Name] items += ['UNIQUE(' + ', '.join(fields) +')'] return request + ', '.join(items) + ');' def ReplaceAllFieldTags(self, a_String, a_BDItem): result = a_String for i in range(len(self.m_Fields)): f = self.m_Fields[i] result = result.replace(f'#{f.m_Name}', str(a_BDItem[i])) return result class Status(Enum): NEW = auto() FINISH = auto() def Test(): f1 = TableField('f1', TableFieldDestiny.KEY, TableFieldType.INT) f2 = TableField('f2', TableFieldDestiny.NAME, TableFieldType.STR) f3 = TableField('f3', TableFieldDestiny.DESC, TableFieldType.STR) f4 = TableField('f4', TableFieldDestiny.STATUS, TableFieldType.ENUM, a_Enum = Status) table = Table('tname', [ f1, f2, f3, f4, ], [[f1], [f2, f3]] ) assert table.GetName() == 'tname' assert table.GetFieldByDestiny(TableFieldDestiny.KEY).m_Name == 'f1' assert table.GetFieldNameByDestiny(TableFieldDestiny.KEY) == 'f1' assert table.GetFieldByDestiny(TableFieldDestiny.KEY).m_Destiny == TableFieldDestiny.KEY assert table.GetFieldByDestiny(TableFieldDestiny.KEY).m_Type == TableFieldType.INT assert table.GetFieldIDByDestiny(TableFieldDestiny.KEY) == 0 assert table.GetFieldByDestiny(TableFieldDestiny.NAME).m_Name == 'f2' assert table.GetFieldNameByDestiny(TableFieldDestiny.NAME) == 'f2' assert table.GetFieldByDestiny(TableFieldDestiny.NAME).m_Destiny == TableFieldDestiny.NAME assert table.GetFieldByDestiny(TableFieldDestiny.NAME).m_Type == TableFieldType.STR assert table.GetFieldIDByDestiny(TableFieldDestiny.NAME) == 1 assert table.GetFieldByDestiny(TableFieldDestiny.DESC).m_Name == 'f3' assert table.GetFieldNameByDestiny(TableFieldDestiny.DESC) == 'f3' assert table.GetFieldByDestiny(TableFieldDestiny.DESC).m_Destiny == TableFieldDestiny.DESC assert table.GetFieldByDestiny(TableFieldDestiny.DESC).m_Type == TableFieldType.STR assert table.GetFieldIDByDestiny(TableFieldDestiny.DESC) == 2 assert table.GetFieldByDestiny(TableFieldDestiny.STATUS).m_Name == 'f4' assert table.GetFieldNameByDestiny(TableFieldDestiny.STATUS) == 'f4' assert table.GetFieldByDestiny(TableFieldDestiny.STATUS).m_Destiny == TableFieldDestiny.STATUS assert table.GetFieldByDestiny(TableFieldDestiny.STATUS).m_Type == TableFieldType.ENUM assert table.GetFieldIDByDestiny(TableFieldDestiny.STATUS) == 3 assert table.GetFieldByDestiny(TableFieldDestiny.PHOTO) == None assert table.GetFieldIDByDestiny(TableFieldDestiny.PHOTO) == None assert table.GetFieldNameByDestiny(TableFieldDestiny.PHOTO) == None assert table.GetFieldsCount() == 4 assert len(table.GetFields()) == 4 print(table.GetInitTableRequest()) assert table.GetInitTableRequest() == 'CREATE TABLE IF NOT EXISTS tname(f1 INTEGER PRIMARY KEY, f2 TEXT, f3 TEXT, f4 TEXT, UNIQUE(f1), UNIQUE(f2, f3));' item = [10, 'i2', 'i3', 'i4'] assert table.ReplaceAllFieldTags('#f1 #f2 #f3 #f4', item) == '10 i2 i3 i4'