-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.py
171 lines (137 loc) · 5.79 KB
/
config.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
"""Config class for loading and saving the configuration file.
Attributes:
config_file_path (str): The path to the configuration file.
config (dict): The configuration dictionary.
Methods:
load_config: Loads the configuration file into a dictionary.
save_config: Saves the configuration dictionary to the configuration file.
set_config: Sets the configuration dictionary.
get_db_configs: Returns the database configurations.
get_database_info: Returns the database information for the specified database name.
add_db_config: Adds a database configuration.
get_db_tables: Returns the table configuration for the specified database name.
get_table_info: Returns the table information for the specified database and table names.
get_last_id: Returns the last id for the table.
get_output_filename: Returns the output filename for the table.
set_last_id: Sets the last id for the table.
"""
import os
import json
import pandas as pd
script_dir = os.path.dirname(os.path.realpath(__file__))
class Config:
"""Config class for loading and saving the configuration file."""
def __init__(self, config_file_path=os.path.join(
os.path.dirname(os.path.realpath(__file__)), 'config.json')):
"""Initializes the Config class."""
self.config_file_path = config_file_path
self.config = self.load_config()
def load_config(self):
"""Loads the configuration file into a dictionary.
Returns:
dict: The configuration dictionary.
"""
with open(self.config_file_path, 'r', encoding="utf8") as config_file:
config = json.load(config_file)
return config
def save_config(self):
"""Saves the configuration dictionary to the configuration file.
"""
with open(self.config_file_path, 'w', encoding="utf8") as config_file:
json.dump(self.config, config_file, indent=4)
def set_config(self, config):
"""Sets the configuration dictionary.
Args:
config (dict): The configuration dictionary.
"""
self.config = config
def get_db_configs(self):
"""Returns the database configurations.
Returns:
dict: The database configurations.
"""
return self.config.get('databases', {})
def get_database_info(self, db_name):
"""Returns the database information for the specified database name.
Args:
db_name (str): The name of the database.
Returns:
dict: The database information.
"""
return self.get_db_configs().get(db_name, {})
def add_db_config(self, db_name, db_config):
"""Adds a database configuration.
Args:
db_name (str): The name of the database.
db_config (dict): The database configuration.
"""
self.config['databases'][db_name] = db_config
def update_db_config(self, db_name, db_config):
"""Updates a database configuration.
Args:
db_name (str): The name of the database.
db_config (dict): The database configuration.
"""
self.config['databases'][db_name].update(db_config)
def get_db_tables(self, db_name):
"""Returns the table configuration for the specified database name.
Args:
db_name (str): The name of the database.
Returns:
list: The table configuration.
"""
return self.get_database_info(db_name).get('tables', [])
def get_table_info(self, db_name, table_name):
"""Returns the table information for the specified database and table names.
Args:
db_name (str): The name of the database.
table_name (str): The name of the table.
Returns:
dict: The table information.
"""
for table in self.get_db_tables(db_name):
if table['name'] == table_name:
return table
return {}
def get_last_id(self, db_name, table_name):
"""Returns the last id for the table.
Args:
db_name (str): The name of the database.
table_name (str): The name of the table.
Returns:
int: The last id for the table.
"""
table_info = self.get_table_info(db_name, table_name)
if 'last_id' in table_info and table_info['last_id'] is not False:
return table_info['last_id']
elif os.path.exists(self.get_output_filename(db_name, table_name)):
return pd.read_csv(self.get_output_filename(db_name, table_name))['id'].max()
else:
return 0
def get_output_filename(self, db_name, table_name,
output_path=os.path.join(script_dir, 'output')):
"""Returns the output filename for the table.
Args:
db_name (str): The name of the database.
table_name (str): The name of the table.
Returns:
str: The output filename for the table.
"""
table_info = self.get_table_info(db_name, table_name)
if 'output' in table_info:
return os.path.join(output_path, f"{ table_info['output'] }")
else:
return os.path.join(output_path, f'{db_name}_{table_name}.csv')
def set_last_id(self, db_name, table_name, last_id):
"""Sets the last id for the table.
Args:
db_name (str): The name of the database.
table_name (str): The name of the table.
last_id (int): The last id for the table.
"""
for table in self.config['databases'][db_name]['tables']:
if table['name'] == table_name:
table['last_id'] = last_id
self.save_config()
return
raise ValueError(f"No table named {table_name} in database {db_name}")