1
0
mirror of https://github.com/bspeice/kiva-dig synced 2024-12-04 20:58:09 -05:00

Python 2 compatibility, merge files

This commit is contained in:
Bradlee Speice 2016-10-25 09:54:44 -04:00
parent df0132d466
commit cc1c73d050
2 changed files with 26 additions and 6 deletions

3
.gitignore vendored
View File

@ -50,3 +50,6 @@ kiva_ds_json.zip
*.json *.json
spark-*/ spark-*/
*.swp *.swp
*.pyc
metastore_db/
derby.log

View File

@ -2,12 +2,18 @@ import zipfile
import json import json
import os import os
kiva_folder = 'kiva-data/' try:
from json import JSONDecodeError
except ImportError:
JSONDecodeError = ValueError # Python 2 compatibility
kiva_root = 'kiva-data/'
kiva_folders = ['loans', 'lenders', 'loans_lenders']
def mkdirs(): def mkdirs():
os.mkdir(kiva_folder) os.mkdir(kiva_root)
for f in map(lambda x: kiva_folder + x, for f in map(lambda x: kiva_root + x,
['loans', 'lenders', 'loans_lenders']): kiva_folders):
if not os.path.isdir(f): if not os.path.isdir(f):
os.mkdir(f) os.mkdir(f)
@ -31,11 +37,22 @@ def unpack_kiva(filename="kiva_ds_json.zip"):
obj_type = json_name.split('/')[0] obj_type = json_name.split('/')[0]
json_content = json_obj[obj_type] json_content = json_obj[obj_type]
formatted = [reformat_json(j) for j in json_content] formatted = [reformat_json(j) for j in json_content]
with open(kiva_folder + json_name, 'w+') as output: with open(kiva_root + json_name, 'w+') as output:
output.write('\n'.join(formatted)) output.write('\n'.join(formatted))
except json.JSONDecodeError: except JSONDecodeError:
print("Error decoding file {}".format(json_name)) print("Error decoding file {}".format(json_name))
def merge_kiva():
for folder in kiva_folders:
files = os.listdir(kiva_root + folder)
out_handle = open(kiva_root + folder + '.json', 'w+')
for f in files:
in_handle = open(os.path.join(kiva_root, folder, f), 'r')
for line in in_handle:
out_handle.write(line)
if __name__ == '__main__': if __name__ == '__main__':
mkdirs() mkdirs()
unpack_kiva() unpack_kiva()
merge_kiva()