Refactor code to clean it up a bit.
This commit is contained in:
parent
ef77c8faed
commit
c28e26d5cc
3 changed files with 87 additions and 87 deletions
|
@ -1,31 +1,32 @@
|
||||||
from django.core.management.base import BaseCommand, CommandError
|
from django.core.management.base import BaseCommand
|
||||||
|
|
||||||
from events.models.locale import Country, SPR, City
|
from events.models.locale import Country, SPR, City
|
||||||
|
|
||||||
# Fields from geoname table, from http://download.geonames.org/export/dump/readme.txt
|
# Fields from geoname table, from http://download.geonames.org/export/dump/readme.txt
|
||||||
GEONAMEID=0
|
GEONAMEID = 0
|
||||||
NAME=1
|
NAME = 1
|
||||||
ASCIINAME=2
|
ASCIINAME = 2
|
||||||
ALTERNATENAMES=3
|
ALTERNATENAMES = 3
|
||||||
LATITUDE=4
|
LATITUDE = 4
|
||||||
LONGITUDE=5
|
LONGITUDE = 5
|
||||||
FEATURE_CLASS=6
|
FEATURE_CLASS = 6
|
||||||
FEATURE_CODE=7
|
FEATURE_CODE = 7
|
||||||
COUNTRY_CODE=8
|
COUNTRY_CODE = 8
|
||||||
COUNTRY_CODE_2=9
|
COUNTRY_CODE_2 = 9
|
||||||
ADMIN1=10
|
ADMIN1 = 10
|
||||||
ADMIN2=11
|
ADMIN2 = 11
|
||||||
ADMIN3=12
|
ADMIN3 = 12
|
||||||
ADMIN4=13
|
ADMIN4 = 13
|
||||||
POPULATION=14
|
POPULATION = 14
|
||||||
ELEVATION=15
|
ELEVATION = 15
|
||||||
DIGITAL_ELEVATION=16
|
DIGITAL_ELEVATION = 16
|
||||||
TIMEZONE=17
|
TIMEZONE = 17
|
||||||
MODIFICATION_DATE=18
|
MODIFICATION_DATE = 18
|
||||||
|
|
||||||
COUNTRY_CACHE = dict()
|
COUNTRY_CACHE = dict()
|
||||||
SPR_CACHE = dict()
|
SPR_CACHE = dict()
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
help = 'Loads city data from GeoNames database file'
|
help = 'Loads city data from GeoNames database file'
|
||||||
|
|
||||||
|
@ -38,22 +39,24 @@ class Command(BaseCommand):
|
||||||
for country in Country.objects.all():
|
for country in Country.objects.all():
|
||||||
COUNTRY_CACHE[country.code] = country
|
COUNTRY_CACHE[country.code] = country
|
||||||
for spr in SPR.objects.all():
|
for spr in SPR.objects.all():
|
||||||
SPR_CACHE["%s.%s"%(spr.country.code, spr.code)] = spr
|
SPR_CACHE["%s.%s" % (spr.country.code, spr.code)] = spr
|
||||||
cities_file = open(options['file'], 'r')
|
with open(options['file'], 'r') as cities_file:
|
||||||
for city_line in cities_file.readlines():
|
for city_line in cities_file.readlines():
|
||||||
city = city_line.split("\t")
|
city = city_line.split("\t")
|
||||||
if len(city) == 19:
|
if len(city) == 19:
|
||||||
if city[FEATURE_CODE].startswith("PPL"):
|
if city[FEATURE_CODE].startswith("PPL"):
|
||||||
country = COUNTRY_CACHE.get(city[COUNTRY_CODE])
|
country = COUNTRY_CACHE.get(city[COUNTRY_CODE])
|
||||||
spr = SPR_CACHE.get("%s.%s"%(city[COUNTRY_CODE], city[ADMIN1]))
|
spr = SPR_CACHE.get("%s.%s" % (city[COUNTRY_CODE], city[ADMIN1]))
|
||||||
if country is not None and spr is not None:
|
if country is not None and spr is not None:
|
||||||
try:
|
try:
|
||||||
City.objects.update_or_create(name=city[NAME], spr=spr, defaults={'tz':city[TIMEZONE], 'longitude':city[LONGITUDE], 'latitude':city[LATITUDE]})
|
City.objects.update_or_create(
|
||||||
except:
|
name=city[NAME],
|
||||||
print("Warning: Failed to load city %s for %s" % (city[NAME], spr))
|
spr=spr,
|
||||||
|
defaults={'tz': city[TIMEZONE], 'longitude': city[LONGITUDE], 'latitude': city[LATITUDE]})
|
||||||
|
except Exception as e:
|
||||||
|
print("Warning: Failed to load city %s for %s (%s)" % (city[NAME], spr, e))
|
||||||
else:
|
else:
|
||||||
print("Short line (%s): %s" % (len(city), city_line))
|
print("Short line (%s): %s" % (len(city), city_line))
|
||||||
cities_file.close()
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
print("No File in options!")
|
print("No File in options!")
|
||||||
|
|
|
@ -1,27 +1,28 @@
|
||||||
from django.core.management.base import BaseCommand, CommandError
|
from django.core.management.base import BaseCommand
|
||||||
|
|
||||||
from events.models.locale import Country
|
from events.models.locale import Country
|
||||||
|
|
||||||
# Fields from geoname table, from http://download.geonames.org/export/dump/readme.txt
|
# Fields from geoname table, from http://download.geonames.org/export/dump/readme.txt
|
||||||
ISO=0
|
ISO = 0
|
||||||
ISO3=1
|
ISO3 = 1
|
||||||
ISO_NUMERIC=2
|
ISO_NUMERIC = 2
|
||||||
FIPS=3
|
FIPS = 3
|
||||||
COUNTRY=4
|
COUNTRY = 4
|
||||||
CAPITAL=5
|
CAPITAL = 5
|
||||||
AREA=6
|
AREA = 6
|
||||||
POPULATION=7
|
POPULATION = 7
|
||||||
CONTINENT=8
|
CONTINENT = 8
|
||||||
TLD=9
|
TLD = 9
|
||||||
CURRENCYCODE=10
|
CURRENCYCODE = 10
|
||||||
CURRENCYNAME=11
|
CURRENCYNAME = 11
|
||||||
PHONE=12
|
PHONE = 12
|
||||||
POSTAL_CODE_FORMAT=13
|
POSTAL_CODE_FORMAT = 13
|
||||||
POSTAL_CODE_REGEX=14
|
POSTAL_CODE_REGEX = 14
|
||||||
LANGUAGES=15
|
LANGUAGES = 15
|
||||||
GEONAMEID=16
|
GEONAMEID = 16
|
||||||
NEIGHBOURS=17
|
NEIGHBOURS = 17
|
||||||
EQUIVALENTFIPSCODE=18
|
EQUIVALENTFIPSCODE = 18
|
||||||
|
|
||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
help = 'Loads country data from GeoNames database file'
|
help = 'Loads country data from GeoNames database file'
|
||||||
|
@ -31,17 +32,15 @@ class Command(BaseCommand):
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
if 'file' in options:
|
if 'file' in options:
|
||||||
countries_file = open(options['file'], 'r')
|
with open(options['file'], 'r') as countries_file:
|
||||||
for country_line in countries_file.readlines():
|
for country_line in countries_file.readlines():
|
||||||
if country_line.startswith("#"):
|
if country_line.startswith("#"):
|
||||||
continue
|
continue
|
||||||
country = country_line.split("\t")
|
country = country_line.split("\t")
|
||||||
if len(country) == 19:
|
if len(country) == 19:
|
||||||
#print("%s - %s" % (country[ISO], country[COUNTRY]))
|
# print("%s - %s" % (country[ISO], country[COUNTRY]))
|
||||||
Country.objects.get_or_create(name=country[COUNTRY], code=country[ISO])
|
Country.objects.get_or_create(name=country[COUNTRY], code=country[ISO])
|
||||||
else:
|
else:
|
||||||
print("Short line (%s): %s" % (len(country), country_line))
|
print("Short line (%s): %s" % (len(country), country_line))
|
||||||
countries_file.close()
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
print("No File in options!")
|
print("No File in options!")
|
||||||
|
|
|
@ -3,10 +3,10 @@ from django.core.management.base import BaseCommand, CommandError
|
||||||
from events.models.locale import Country, SPR, City
|
from events.models.locale import Country, SPR, City
|
||||||
|
|
||||||
# Fields from geoname table, from http://download.geonames.org/export/dump/readme.txt
|
# Fields from geoname table, from http://download.geonames.org/export/dump/readme.txt
|
||||||
COMBINED_CODE=0
|
COMBINED_CODE = 0
|
||||||
NAME=1
|
NAME = 1
|
||||||
ASCIINAME=2
|
ASCIINAME = 2
|
||||||
GEONAMEID=3
|
GEONAMEID = 3
|
||||||
|
|
||||||
COUNTRY_CACHE = dict()
|
COUNTRY_CACHE = dict()
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ class Command(BaseCommand):
|
||||||
# Preload country cache
|
# Preload country cache
|
||||||
for country in Country.objects.all():
|
for country in Country.objects.all():
|
||||||
COUNTRY_CACHE[country.code] = country
|
COUNTRY_CACHE[country.code] = country
|
||||||
spr_file = open(options['file'], 'r')
|
with open(options['file'], 'r') as spr_file:
|
||||||
for spr_line in spr_file.readlines():
|
for spr_line in spr_file.readlines():
|
||||||
if spr_line.startswith("#"):
|
if spr_line.startswith("#"):
|
||||||
continue
|
continue
|
||||||
|
@ -35,7 +35,5 @@ class Command(BaseCommand):
|
||||||
SPR.objects.get_or_create(name=spr[NAME], code=SPR_CODE, country=country)
|
SPR.objects.get_or_create(name=spr[NAME], code=SPR_CODE, country=country)
|
||||||
else:
|
else:
|
||||||
print("Short line (%s): %s" % (len(spr), spr_line))
|
print("Short line (%s): %s" % (len(spr), spr_line))
|
||||||
spr_file.close()
|
|
||||||
|
|
||||||
else:
|
else:
|
||||||
print("No File in options!")
|
print("No File in options!")
|
||||||
|
|
Loading…
Reference in a new issue