Example #1
0
def add_student(table: DBTable, index: int, **kwargs) -> None:
    info = dict(ID=1_000_000 + index,
                First=f'John{index}',
                Last=f'Doe{index}',
                Birthday="23/11/2000")
    info.update(**kwargs)
    table.insert_record(info)
Example #2
0
def add_student(table: DBTable, index: int, **kwargs) -> None:
    info = dict(ID=1_000_000 + index,
                First=f'John{index}',
                Last=f'Doe{index}',
                Birthday=dt.datetime(2000, 2, 1) + dt.timedelta(days=index))
    info.update(**kwargs)
    table.insert_record(info)
Example #3
0
 def __init__(self):
     with shelve.open(os.path.join(db_api.DB_ROOT, "DB.db"),
                      writeback=True) as db:
         for key in db:
             db_table = DBTable(key, db[key][0], db[key][1])
             db_table.list_index = db[key][2]
             DataBase.__dict_tables__[str(key)] = db_table
    def create_table(self, table_name: str, fields: List[DBField],
                     key_field_name: str) -> DBTable:
        if not os.path.isdir(f"{DB_ROOT}/{table_name}"):
            try:
                os.makedirs(f"{DB_ROOT}/{table_name}")
                new_table = DBTable(table_name, fields, key_field_name)

                with open(f"{DB_ROOT}/{table_name}/{table_name}.json",
                          "w") as tables:
                    json.dump(
                        {
                            "len":
                            0,
                            "name":
                            table_name,
                            "fields": [{
                                field.name: str(field.type)
                            } for field in fields],
                            "key_field_name":
                            key_field_name
                        }, tables)

            except ValueError:
                self.delete_table(table_name)
                raise ValueError

            self.my_tables.update({table_name: new_table})
            return new_table

        raise FileExistsError
Example #5
0
    def create_table(self, table_name: str, fields: List[DBField],
                     key_field_name: str) -> DBTable:
        print("=== create_table ===")
        with open(DB_ROOT / "DataBase.json", "r") as DB_file:
            db_data = json.load(DB_file)

            # if table_name in db_data.keys():
            #     raise FileExistsError("The table is exists")

        with open(DB_ROOT / f"{table_name}.csv", "w") as table_file:
            table = csv.writer(table_file)
            table.writerow([f.name for f in fields])

            db_data[table_name] = {
                "fields": [{
                    f.name: str(f.type)
                } for f in fields],
                "key": key_field_name
            }

            # db_data["num_tables"] += 1

        with open(DB_ROOT / "DataBase.json", "w") as DB_file:
            # db_data = json.load(DB_file)
            json.dump(db_data, DB_file)

        return DBTable(table_name, fields, key_field_name)
Example #6
0
    def create_table(self,
                     table_name: str,
                     fields: List[DBField],
                     key_field_name: str) -> DBTable:

        new_table = DBTable(table_name, fields, key_field_name)
        self.db_table[table_name] = new_table
        return new_table
Example #7
0
    def get_table(self, table_name: str) -> DBTable:
        print("=== get_table ===")
        with open(DB_ROOT / "DataBase.json", "r+") as DB_file:
            db_data = json.load(DB_file)
            # fields_list = [DBField(f.key(), f[f.key()]) for f in db_data[table_name]["fields"]]
            fields_list = []
            for dict_ in db_data[table_name]["fields"]:
                print(dict_)
                fields_list.append(dict_)

        return DBTable(table_name, fields_list, db_data[table_name]["key"])
Example #8
0
 def get_table(self, table_name: str) -> DBTable:
     if table_name in self.my_tables.keys():
         return self.my_tables[table_name]
     if os.path.isdir(f"{DB_ROOT}/{table_name}"):
         with open(f"{DB_ROOT}/{table_name}/{table_name}.json") as tables:
             table_data = json.load(tables)
             new_table = DBTable(table_data["name"], table_data["filed"],
                                 table_data["key_field_name"])
             self.my_tables[table_name] = new_table
             return new_table
     raise NameError
Example #9
0
    def get_table(self, table_name: str) -> DBTable:
        if table_name in self.my_tables.keys():
            return self.my_tables[table_name]

        if os.path.isdir(f"{DB_ROOT}/{table_name}"):
            with open(f"{DB_ROOT}/{table_name}/{table_name}.json") as tables:
                table_data = json.load(tables)
                new_table = DBTable(table_data["name"],
                                    [DBField(list(item.keys())[0], list(item.values())[0]) for item in table_data["fields"]],
                                    table_data["key_field_name"])
                self.my_tables[table_name] = new_table
                return new_table
        raise NameError
Example #10
0
 def create_table(self,
                  table_name: str,
                  fields: List[DBField],
                  key_field_name: str) -> DBTable:
     self.num_of_tables += 1
     self.tables_array.append(DBTable(table_name, fields, key_field_name))
     with open(f"{table_name}.csv", "w") as new_file:
         csv_writer = csv.writer(new_file)
         data_in_line = []
         for field in fields:
             data_in_line.append(field.name)
         csv_writer.writerow(data_in_line)
     return self.tables_array[self.num_of_tables - 1]
Example #11
0
    def create_table(self, table_name: str, fields: List[DBField],
                     key_field_name: str) -> DBTable:

        if DataBase.__dict_tables__.get(table_name):
            return DataBase.__dict_tables__[table_name]
        flag = 0
        for field in fields:
            if key_field_name == field.name:
                flag = 1
        if flag == 0:
            raise ValueError
        data_table = shelve.open(os.path.join(db_api.DB_ROOT,
                                              table_name + ".db"),
                                 writeback=True)
        data_table.close()
        db_table = DBTable(table_name, fields, key_field_name)
        db_table.list_index = []
        DataBase.__dict_tables__[table_name] = db_table
        with shelve.open(os.path.join(db_api.DB_ROOT, "DB.db"),
                         writeback=True) as db:
            db[table_name] = [fields, key_field_name, list()]
        return db_table
Example #12
0
    def get_table(self, table_name: str) -> DBTable:
        print("=== get_table ===")
        with open(DB_ROOT / "DataBase.json", "r+") as DB_file:
            db_data = json.load(DB_file)

            print(db_data.keys())
            if table_name not in db_data.keys():
                raise FileNotFoundError

        fields_list = []
        for dic in db_data[table_name]["fields"]:
            fields_list.append(dic)

        return DBTable(table_name, fields_list, db_data[table_name]["key"])
Example #13
0
    def create_table(self, table_name: str, fields: List[DBField],
                     key_field_name: str) -> DBTable:
        dictionary = read_tables()
        if table_name in dictionary:
            raise TableExistError

        with open(DB_ROOT / 'tables.json', 'w+') as tables_file:
            db_table = DBTable(table_name, fields, key_field_name)
            create_table_file(db_table)

            dictionary[table_name] = {
                'fields': [field.name for field in fields],
                'key field name': key_field_name
            }
            self.num += 1

            json.dump(dictionary, tables_file)

        return db_table
Example #14
0
    def create_table(self, table_name: str, fields: List[DBField],
                     key_field_name: str) -> DBTable:
        if not os.path.isdir(f"{DB_ROOT}/{table_name}"):
            os.makedirs(f"{DB_ROOT}/{table_name}")
            new_table = DBTable(table_name, fields, key_field_name)

            with open(f"{DB_ROOT}/{table_name}/{table_name}.json",
                      "w") as tables:
                json.dump(
                    {
                        "name": table_name,
                        # "filed": [{field.name: field.type} for field in fields],
                        "key_field_name": key_field_name
                    },
                    tables)
            self.my_tables.update({table_name: new_table})
            return new_table

        raise FileExistsError
Example #15
0
 def get_table(self, table_name: str) -> DBTable:
     dictionary = read_tables()
     return DBTable(table_name, dictionary[table_name]['fields'],
                    dictionary[table_name]['key field name'])