首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >统计pandas df列中子字符串列表的出现次数

统计pandas df列中子字符串列表的出现次数
EN

Stack Overflow用户
提问于 2019-07-27 08:37:41
回答 2查看 53关注 0票数 1

我想要计算子字符串列表在包含长字符串的列中出现的次数,并在pandas df中创建一个count列

代码语言:javascript
复制
      Input:          
     ID    History

     1     USA|UK|IND|DEN|MAL|SWE|AUS
     2     USA|UK|PAK|NOR
     3     NOR|NZE
     4     IND|PAK|NOR

       lst=['USA','IND','DEN']


     Output :
     ID    History                      Count

     1     USA|UK|IND|DEN|MAL|SWE|AUS    3
     2     USA|UK|PAK|NOR                1
     3     NOR|NZE                       0
     4     IND|PAK|NOR                   1
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-07-27 09:14:19

使用lambda:

代码语言:javascript
复制
df.History.apply(lambda x: len([i for i in x.split("|") if i in lst]))

结果

代码语言:javascript
复制
0    3
1    1
2    0
3    1
票数 0
EN

Stack Overflow用户

发布于 2019-07-27 08:40:09

以下是str.count的一种方法

代码语言:javascript
复制
df1.History.str.count('|'.join(lst))
Out[316]: 
0    3
1    1
2    0
3    1
Name: History, dtype: int64

#df1['Count']= df1.History.str.count('|'.join(lst))
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57228301

复制
相关文章

相似问题

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