亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如果在數據框列中找到,則返回字符串的關鍵字

如果在數據框列中找到,則返回字符串的關鍵字

函數式編程 2021-06-04 21:05:28
我有一個字符串。我需要查找該字符串中的關鍵字是否存在于我的數據框中。如果存在,我需要返回該關鍵字。細繩:question="Joe is Available"question=question.upper()str_list=question.split()str_list出[107]:['JOE', 'IS', 'AVAILABLE']數據框:df=pd.DataFrame({"Person1":("Ash","Joe","Harry"),"Person2":("Abe","Lisa","Katty",),"Person3":("Sam","Max","Stone")})df=df.apply(lambda x: x.astype(str).str.upper())Person1 Person2 Person3ASH     ABE     SAMJOE     LISA    MAXHARRY   KATTY   STONE我的嘗試:return_field=""for x in str_list:    print(x)    for i in df.iterrows():        if(df.str.contains(x)):            return_field=x給我 AttributeError: 'DataFrame' 對象沒有屬性 'str'預期產出由于 Joe 出現在數據框中,它應該返回我“Joe”
查看完整描述

2 回答

?
慕姐8265434

TA貢獻1813條經驗 獲得超2個贊

如果您重復執行此操作,您可能希望通過 .hash 散列您的值set。此外,您可以使用mapwithstr.upper將數據幀值轉換為大寫1:


str_all = set(map(str.upper, df.values.ravel()))


question = "Joe is Available"

str_search = set(question.upper().split())


res = str_search & str_all


# {'JOE'}

1您可以使用pd.DataFrame.apply+ lambda,但不推薦這樣做。pd.Series.str目前,字符串操作 via是出了名的慢。lambda在頂部添加一個循環會使情況變得更糟。


查看完整回答
反對 回復 2021-06-09
?
白板的微信

TA貢獻1883條經驗 獲得超3個贊


In [741]: [x for x in str_list if x in df.values]

Out[741]: ['JOE']


查看完整回答
反對 回復 2021-06-09
  • 2 回答
  • 0 關注
  • 145 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號