-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild_database.py
62 lines (53 loc) · 1.9 KB
/
build_database.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
import os
import click
from zipcode_db import ZipCodeDB
def delete_db_file(filename):
if(os.path.isfile(filename)):
os.unlink(filename)
def load_zipcodes_file(filename):
fp = open(filename)
content = fp.readlines()
fp.close()
return content
@click.command()
@click.option('--zipcode-file', default="ceps.txt", help='Filename containing zipcodes.')
@click.option('--output-database', default="./base/cep.db", help='Output database location.')
def build(zipcode_file, output_database):
click.echo(click.style(f'Building zipcodes database {zipcode_file}', fg='green'))
# Read zip code file
content = load_zipcodes_file(zipcode_file)
# Delete database if exists
delete_db_file(output_database)
# Create database
zipcode_db = ZipCodeDB(output_database, create=True)
# Populate database
count = 0
click.echo(click.style(f'Zip Codes readed {len(content)}', fg='green'))
with click.progressbar(content) as bar:
for cep in bar:
items = cep.split('\t')
cep = items[0].strip()
cidade, estado = items[1].split('/')
cidade = cidade.strip()
estado = estado.strip()
if(len(items) >= 3):
bairro = items[2].strip()
else:
bairro = None
if(len(items) >= 4):
logradouro = items[3].strip()
else:
logradouro = None
if(len(items) >= 5):
descricao = items[4].strip()
else:
descricao = None
zipcode_db.insert(cep, cidade, estado, bairro, logradouro, descricao)
count += 1
if(len(content) == count):
click.echo(click.style(f'Zip Codes writed {count}', fg='green'))
else:
click.echo(click.style(f'Zip Codes writed {count}', fg='red', bg='yellow'))
zipcode_db.commit()
if(__name__ == '__main__'):
build()