pandas按属性值筛选,isin

本文介绍使用Pandas库进行数据筛选的两种方法,包括利用isin()函数和apply()函数结合lambda表达式的技巧,同时指出在复杂条件下的应用局限及错误处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import pandas as pd
df = pd.DataFrame({'countries':['US','UK','Germany','China']})
df
Out[34]: 
  countries
0        US
1        UK
2   Germany
3     China

说明实例如上,有两种方式,第一种:

df1=df[df["countries"].isin(countries)]

df1
Out[28]: 
  countries
1        UK
3     China

df2=df[~df.countries.isin(countries)]
df2
Out[30]: 
  countries
0        US
2   Germany

第二种:

criterion = lambda row: row['countries'] not in countries

not_in = df[df.apply(criterion, axis=1)]

not_in
Out[33]: 
  countries
0        US

有一种情况用.isin会报错

criterion = lambda row: row['TOLLGATE_ID'] in gate_id_list and row["NEXT_TOLLGATE_ID"] in gate_id_list
test_df=test_df[test_df.apply(criterion,axis=1)]
 
#会报错    
test_df=test_df[test_df["TOLLGATE_ID"].isin(gate_id_list) and test_df["NEXT_TOLLGATE_ID"].isin(gate_id_list)]

并且row['TOLLGATE_ID',"NEXT_TOLLGATE_ID"] in gate_id_list 或者.isin

的写法不可以

参考:https://cloud.tencent.com/developer/ask/93371

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值