首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计算字典列表中键的存在号

计算字典列表中键的存在号
EN

Stack Overflow用户
提问于 2022-02-08 19:33:59
回答 2查看 76关注 0票数 0

我使用gspreadpandas将我的google表转换为list of dictionaries。示例列表如下所示:(这是一个非常长的列表,所以我只列出了几行)

代码语言:javascript
复制
mylist = [
{'StartDate': '2021-10-02', 'ID': 11773, 'Receiver': Mike, 'Days':66 },
{'StartDate': '2021-10-03', 'ID': 15673, 'Receiver': Jane, 'Days':65}, 
{'StartDate': '2021-10-03', 'ID': 15673, 'Receiver': Jane, 'Days':65},
{'StartDate': '2021-10-03', 'ID': 15673, 'Receiver': Mike, 'Days':65},
... 
{'StartDate': '2021-10-5', 'ID': 34653, 'Receiver': Jack, 'Days':63}]

我想要计算一些键存在的数量,例如MikeJaneReceiver字段中。我尝试了以下方法来计算行的总数,我想我可以使用类似的代码

代码语言:javascript
复制
counts = collections.Counter()
for d in package2019:
    counts.update(d.keys())
count_list = [{c: counts[c] for c in d} for d in mylist]

我只是不知道该怎么计算一些钥匙的存在数。我刚接触过python,我在网上到处搜索,没有任何运气

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-02-08 19:39:00

您可以使用len()和生成器:

代码语言:javascript
复制
len(tuple(d for d in my_list if d['Receiver'] == 'Mike'))

您可以使用len()和filter():

代码语言:javascript
复制
len(tuple(filter(lambda d: d['Receiver'] == 'Mike', my_list)))

您可以使用sum()和map():

代码语言:javascript
复制
sum(map(lambda d: d['Receiver'] == 'Mike', my_list))

这包括所有的Mikes,如果您也想要Janes,您必须将它添加到条件中。

票数 1
EN

Stack Overflow用户

发布于 2022-02-08 19:49:14

您可以使用列表理解来构建一个接收者列表。然后将该列表传递给collections.Counter,以获取每个接收器在mylist中出现多少次的计数。

代码语言:javascript
复制
from collections import Counter
receivers = [d['Receiver'] for d in mylist]
counts = Counter(receivers)

输出:

代码语言:javascript
复制
Counter({'Mike': 2, 'Jane': 2, 'Jack': 1})
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71039865

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档