我有一个包含字典的列表,例如:
[{'name':'Bernard','age':7},{'name':'George','age':4},{'name':'Reginald','age':6}]
我想检查一个字符串值是否与列表中任何字典的'name'值相同。例如,'Harold'将返回False,而'George'将返回True。我知道可以通过循环遍历列表中的每个项目来实现这一点,但我想知道是否有更有效的方法?我有一个包含字典的列表,例如:
[{'name':'Bernard','age':7},{'name':'George','age':4},{'name':'Reginald','age':6}]
我想检查一个字符串值是否与列表中任何字典的'name'值相同。例如,'Harold'将返回False,而'George'将返回True。我知道可以通过循环遍历列表中的每个项目来实现这一点,但我想知道是否有更有效的方法?如果你只有这个字典列表,那么没有更有效的方法。
但是,如果你需要频繁检查,你可以提取一个包含姓名:年龄项的字典:
l = [{'name':'Bernard','age':7},{'name':'George','age':4},{'name':'Reginald','age':6}]
d = dict((i['name'], i['age']) for i in l)
现在你有一个变量d
:
{'Bernard': 7, 'George': 4, 'Reginald': 6}
现在你可以进行检查:
'Harold' in d -> False
'George' in d -> True
使用这种方法比迭代原始列表要快得多。
s = set((i['name'] for i in l))
。+1 - Chinmay KanchiL.sort(key=itemgetter('name'))
并使用 bisect
模块执行二分查找。在实践中,你可以像 @Chinmay Kanchi 建议的那样使用集合或者像 @KennyTM 的答案中使用 any()
进行线性搜索。 - jfs有一种比循环更高效的方法。如果使用operators.itemgetter
,则可以进行简单的if x in y检查
#to simply check if the list of dicts contains the key=>value pair
'George' in map(itemgetter('name'), list_of_dicts)
#if you want to get the index
index = map(itemgetter('name'), list_of_dicts).index("George") if 'George' in map(itemgetter('name'), list_of_dicts) else None
list(map(itemgetter('name'), list_of_dicts)).index('George')
。如果list.index()
未找到任何项,则还可以将其放置在try..except ValueError
中,而不是执行两个itemgetter()
查找。请注意,翻译并没有改变原来的意思,并尽可能地使内容通俗易懂。 - timss我觉得列表推导式在这里也可以解决问题。
names = [i['name'] for i in l]
然后像这样使用:
'Bernard' in names (True)
'Farkle' in names (False)
或者一行代码(如果只有一个检查)
'Bernard' in [i['name'] for i in l] (True)
l = [{'name':'Bernard','age':7},{'name':'George','age':4},{'name':'Reginald','age':6}]
search_for = 'George'
print True in map(lambda person: True if person['name'].lower() == search_for.lower() else False, l )
smf = [{'name':'Bernard','age':7},{'name':'George','age':4},{'name':'Reginald','age':6}]
def names(d):
for i in d:
for key, value in i.iteritems():
if key == 'name':
yield value
In [5]: 'Bernard' in names(smf)
Out[5]: True
In [6]: 'Bernardadf' in names(smf)
Out[6]: False
Person
的类,其中包含属性name
和age
,然后创建一个列表或字典来存储它们呢? - Björn PollexPerson = collections.namedtuple('Person', 'name age')
代替@Space_C0wb0y建议的字典:L = [Person(**d) for d in L]
。 - jfs