Added test map list, implemented map processing including combining into single output map file

This commit is contained in:
Mike C 2016-01-12 16:17:06 -05:00
parent 7a6ae6c093
commit e78aa8db23
2 changed files with 72 additions and 0 deletions

2
lists/test.txt Normal file
View file

@ -0,0 +1,2 @@
http://download.geofabrik.de/north-america/canada/prince-edward-island-latest.osm.pbf
http://download.geofabrik.de/north-america/us/delaware-latest.osm.bz2

70
process_maps.py Executable file
View file

@ -0,0 +1,70 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import subprocess, sys, os, pprint, datetime, argparse, time
base_path = os.path.dirname(os.path.realpath(__file__))
FNULL = open(os.devnull, 'w')
wget_cmd = '/usr/bin/wget'
bunzip2_cmd = '/usr/bin/bunzip2'
if __name__ == '__main__':
current_timestamp = datetime.datetime.now().strftime('%Y%m%d-%H%M')
parser = argparse.ArgumentParser()
parser.add_argument('--map-list', action='store')
#TODO: Add argument to pass path to osmosis
#TODO: Add argument to pass path to output dir
args = parser.parse_args()
map_list = []
with open(args.map_list, 'r') as maps:
for line in maps:
map_list.append(line.strip())
print('Creating working directories')
if not os.path.exists('out'):
os.makedirs('out')
os.chdir('out')
if not os.path.exists(current_timestamp):
os.makedirs(current_timestamp)
os.chdir(current_timestamp)
if not os.path.exists('dl'):
os.makedirs('dl')
print('Downloading maps')
for line in map_list:
print(' ', end='')
print(line)
subprocess.run([wget_cmd, '-P', 'dl', line.strip()], stdout=FNULL, stderr=subprocess.STDOUT)
print(' Sleeping 1m to prevent throttle/blocking')
time.sleep(300) # Seconds
print('Decompressing maps (if necessary)')
for dirpath, dirnames, filenames in os.walk('dl'):
for file in filenames:
if file.endswith('bz2'):
print(' ', end='')
print(file)
subprocess.run([bunzip2_cmd, os.path.join(dirpath, file)])
print('Processing maps using osmosis')
files_to_process = []
for dirpath, dirnames, filenames in os.walk('dl'):
for file in filenames:
print(' Found map: ', end='')
print(os.path.join(dirpath, file))
files_to_process.append(os.path.join(dirpath, file))
osmosis_cmd = [os.path.join(base_path, 'bin', 'osmosis', 'bin', 'osmosis')]
for file in files_to_process:
if file.endswith('osm'):
osmosis_cmd.extend(['--rx', 'file=' + file])
elif file.endswith('pbf'):
osmosis_cmd.extend(['--rb', 'file=' + file])
for x in range(0, len(files_to_process) - 1):
osmosis_cmd.append('--merge')
osmosis_cmd.extend(['--mapfile-writer', 'file=output.map'])
subprocess.run(osmosis_cmd)