Skip to content

Instantly share code, notes, and snippets.

@shkpk
Created December 5, 2019 06:09
Show Gist options
  • Save shkpk/b8c7d782fbb96dd53eaa0281c5e5e130 to your computer and use it in GitHub Desktop.
Save shkpk/b8c7d782fbb96dd53eaa0281c5e5e130 to your computer and use it in GitHub Desktop.
# csv2xml.py
# FB - 201010107
# First row of the csv file must be header!
# example CSV file: myData.csv
# id,code name,value
# 36,abc,7.6
# 40,def,3.6
# 9,ghi,6.3
# 76,def,99
import csv
csvFile = 'dataset_us_car_price_data.csv'
xmlFile = 'dataset_us_car_price_data.xml'
csvData = csv.reader(open(csvFile))
xmlData = open(xmlFile, 'w')
xmlData.write('<?xml version="1.0"?>' + "\n")
# there must be only one top-level tag
xmlData.write('<ref id="B1">' + "\n")
rowNum = 0
for row in csvData:
if rowNum == 0:
tags = row
# replace spaces w/ underscores in tag names
for i in range(len(tags)):
tags[i] = tags[i].replace(' ', '_')
else:
xmlData.write('<row>' + "\n")
for i in range(len(tags)):
xmlData.write(' ' + '<' + tags[i] + '>' \
+ row[i] + '</' + tags[i] + '>' + "\n")
xmlData.write('</row>' + "\n")
rowNum +=1
xmlData.write('</ref>' + "\n")
xmlData.close()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment