更新python中字典列表的值

2024-04-25 16:43:18 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个CSV文件,如下所示:

Martin;Sailor;-0.24
Joseph_4;Sailor;-0.12
Alex;Teacher;-0.23
Maria;Teacher;-0.57

我的目标是为每个工作创建一个包含词典的列表。

例如:

list_of_jobs = [{'Job' : Sailor, 'People' : ['Martin', 'Joseph']}
                 {'Job' : Teacher, 'People' : ['Alex', 'Maria']}
] 

我确实创建了字典,但是我不知道如何更新list_of_jobs['People']的值

有人能帮我吗?


Tags: 文件ofcsv目标jobsjobpeoplelist
3条回答

如果你有这样的字典列表:

list_of_jobs = [
  {'Job' : 'Sailor', 'People' : ['Martin', 'Joseph']},
  {'Job' : 'Teacher', 'People' : ['Alex', 'Maria']}
]

你可以通过索引访问词典。

list_of_jobs[0]

Output:
{'Job' : 'Sailor', 'People' : ['Martin', 'Joseph']}

如果要访问第一个词典的“People”属性,可以这样做:

list_of_jobs[0]['People']

Output:
['Martin', 'Joseph']

如果要修改该人员列表的值,可以使用append()添加项,或使用pop()从列表中删除项。

list_of_jobs[0]['People'].append('Andrew')
list_of_jobs[0]['People'].pop(1)

现在,列出的工作将处于以下状态:

[
  {'Job' : 'Sailor', 'People' : ['Martin', 'Andrew']},
  {'Job' : 'Teacher', 'People' : ['Alex', 'Maria']}
]

您的数据结构不适合此项工作;请考虑使用不同的数据结构,然后最终更改为您的数据结构:

data = "Martin;Sailor;-0.24 Joseph_4;Sailor;-0.12 Alex;Teacher;-0.23 Maria;Teacher;-0.57"
data = [r.split()[-1] for r in data.split(';')]
# data = ['Martin', 'Sailor', 'Joseph_4', 'Sailor', 'Alex', 'Teacher', 'Maria', 'Teacher', '-0.57']

# for the moment use one dict keyed with jobs for easy updating
out = {}
for name, job in zip(data[::2], data[1::2]):
    out.setdefault(job, []).append(name)
# out = {'Sailor': ['Martin', 'Joseph_4'], 'Teacher': ['Alex', 'Maria']}

# in the very end, convert to desired output format
out = [{'Job': job, 'People': people} for job, people in out.items()]
# out = [{'Job': 'Sailor', 'People': ['Martin', 'Joseph_4']}, {'Job': 'Teacher', 'People': ['Alex', 'Maria']}]
job_dict={}
job_dict['Sailor']=['Martin','Joseph']
job_dict['Teacher']=['Alex','Maria']

如果您想添加“马可斯”作为水手,您可以:

(job_dict['Sailor']).append('Marcos')

相关问题 更多 >