Update sahana-lang-csv.py to support both csv and xls.

This commit is contained in:
Disassembler 2017-09-10 21:11:48 +02:00
parent 7d45652126
commit 2d1b7eaecb

View File

@ -1,26 +1,32 @@
#!/usr/bin/env python #!/usr/bin/env python
from __future__ import print_function
from pprint import pprint
import csv import csv
import os
import sys
import xlrd
dictionary = {} if len(sys.argv) == 1:
with open('cz.csv', 'rb') as csvfile: print('Usage: {} input.(csv|xls)'.format(sys.argv[0]))
sys.exit(1)
basename, extension = os.path.splitext(sys.argv[1].lower())
translations = {}
if extension == '.csv':
with open(sys.argv[0], 'rb') as csvfile:
reader = csv.reader(csvfile, delimiter=',', quotechar='\'') reader = csv.reader(csvfile, delimiter=',', quotechar='\'')
for line in reader: for line in reader:
dictionary[line[1]] = line[2] translations[line[1].encode('utf-8')] = line[2].encode('utf-8')
elif extension == '.xls':
with open('cz.py', 'wb') as langfile: sheet = xlrd.open_workbook(sys.argv[0]).sheet_by_index(0)
langfile.write(str(dictionary))
--
import xlrd
from pprint import pprint
dictionary = {}
sheet = xlrd.open_workbook('cz.xls').sheet_by_index(0)
for i in range(1, sheet.nrows): for i in range(1, sheet.nrows):
row = sheet.row(i) row = sheet.row(i)
dictionary[row[1].value.encode('utf-8')] = row[2].value.encode('utf-8') translations[row[1].value.encode('utf-8')] = row[2].value.encode('utf-8')
else:
print('Unknown input file extension')
sys.exit(1)
with open('cz.py', 'wb') as langfile: with open('{}.py'.format(basename), 'wb') as langfile:
pprint(dictionary, langfile) pprint(translations, langfile)