Python新手看这里。我有一个列表字典,如下所示:
d = {
1: ['foo', 'foo(1)', 'bar', 'bar(1)'],
2: ['foobaz', 'foobaz(1)', 'apple', 'apple(1)'],
3: ['oz', 'oz(1)', 'boo', 'boo(1)']
}
我想弄清楚如何遍历字典的键和相应的列表值,并删除每个列表中带有括号尾部的所有字符串。到目前为止,这就是我所拥有的:
for key in keys:
for word in d[key]...: # what else needs to go here?
regex = re.compile('\w+\([0-9]\)')
re.sub(regex, '', word) # Should this be a ".pop()" from list instead?
我想通过列表理解来做到这一点,但正如我所说,我找不到太多关于循环遍历字典键和列表的相应字典值的信息。最有效的设置方式是什么?
最佳答案
你可以重新构建字典,只让没有括号的元素通过:
d = {k:[elem for elem in v if not elem.endswith(')')] for k,v in d.iteritems()}
关于python - 如何遍历包含列表的字典值并删除项目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15949396/