python - 在 Python 的 csv 字典中创建字典列表

标签 python list csv dictionary

我有一个看起来像这样的 csv:

Name;Category;Address
McFood;Fast Food;Street 1
BurgerEmperor;Fast Food;Way 1
BlueFrenchHorn;French;Street 12
PetesPizza;Italian;whatever
SubZero;Fast Food;Highway 6

我想制作一个以类别为键的字典和一个以剩余数据为值的字典列表。所以它看起来像这样:

{'Fast Food' : [{'Name': 'McFood', 'Address': 'Street 1'}, 
                {'Name': 'BurgerEmperor', 'Address': 'Way 1'}],
                ...],
 'French' : [{'Name': 'BlueFrenchHorn', 'Address': 'Street12'}],
...}

(此处缩进以提高可读性)。

我试过像下面的片段一样,但我没有从那里得到任何东西:

import csv
mydict={}

with open ('food.csv', 'r') as csvfile:
        #sniff to find the format
        fileDialect = csv.Sniffer().sniff(csvfile.read(1024))
        csvfile.seek(0)
        #read the CSV file into a dictionary
        dictReader = csv.DictReader(csvfile, dialect=fileDialect)
        for row in dictReader:
            mycategory= row["Category"]
            del row("Category")
            mydict[mycategory]=row

最佳答案

使用 collections.defaultdict :

import csv
from collections import defaultdict

mydict = defaultdict(list)  # <---

with open ('food.csv', 'r') as csvfile:
    fileDialect = csv.Sniffer().sniff(csvfile.read(1024))
    csvfile.seek(0)
    dictReader = csv.DictReader(csvfile, dialect=fileDialect)
    for row in dictReader:
        mycategory= row.pop("Category")
        mydict[mycategory].append(row)  # Will put a list for not-existing key

mydict = dict(mydict)  # Convert back to a normal dictionary (optional)

关于python - 在 Python 的 csv 字典中创建字典列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25891451/

相关文章:

python - SQLAlchemy:在查询对象上调用 list() 时会发生什么?

Python XPath/libxml2 命名空间查询

Java/Grails - 如何从没有索引的列表中删除元素

java - 在 Java 中创建列表的二维数组

python - 在列表中查找字符串的索引

python - 从 pandas 数据帧写入 .csv 文件,并使用连续空格作为分隔符

python - 如何更改堆积的 pyplot 图表的列颜色以指示另一列是真还是假?

python - 在 ubuntu 上将 setuptools 从 20.10.1 降级到 18.2

python - 为什么数据框无法在 matplotlib 中绘制 3D 图形?

python - 如何将 spark 数据帧保存到 HDFS 上的 csv?