I need to process a file like this
JavaScript
x
6
1
keyword,synonym,bidirectional
2
5487500j,54875,false
3
76x76,76 x 76,true
4
feuille,"papier,ramette",false
5
7843000j,78430,false
6
and I need to transform it to a dict :
JavaScript
1
2
1
{'5487500j':'54875', '76x76':'76 x 76','feuille':['papier','ramette'], '7843000j':'78430'}
2
I don’t succeed in any fast and elegant way to deal
Advertisement
Answer
Let me first specify what I have understood from your requirement.
- You input is a csv file, with optionaly quoted fields: ok the csv module can parse it
- The first field of each record will be used as a key in a dictionary
- the third field is ignored
- the second field will be the value in the dictionary. If it does not contain a comma, it will be used as is, else the value will be a splitted list
You should always write down in plain english (or whatever you first language is) a detailed specification of what you want to do before trying to code anything. Because the coding part should only be the translation of the spec.
Here the Python code (for my spec…) could be:
JavaScript
1
7
1
with open(inputfile) as fd:
2
rd = csv.reader(fd) # you files uses the default for quoting and delimiter
3
_ = next(rd) # skip header line
4
result = {}
5
for row in rd:
6
result[row[0]] = row[1].split(',') if ',' in row[1] else row[1]
7
In fact a comprehension would be more Pythonic than the loop:
JavaScript
1
3
1
result = {row[0]: row[1].split(',') if ',' in row[1] else row[1]
2
for row in rd}
3