假设我有以下数据帧:
ter_id shstr value
6 2018002000000 201 1740.0
7 2018002000000 201 10759.0
8 2018002000002 201 2.0
如何筛选出最后六个符号为ter_id
为零的行?也就是说,期望的输出是:
ter_id shstr value
8 2018002000002 201 2.0
我做了一个布尔函数
def is_total(ter_id: str) -> bool:
if ter_id[:-6] == "000000":
return True
return False
但it使用失败并出现错误:
dataset.filter(is_total(dataset.ter_id))
...
ValueError: The truth value of a Series is ambiguous. Use a.empty, a.bool(), a.item(), a.any() or a.all().
熊猫版是1.0.1
对于基于列值过滤数据帧,很少有理由编写自己的函数。您可以将条件作为布尔掩码传递到df.loc[](假设您的数据帧名为df)
通过} 获取所有不匹配的行:
[-6:]
更改最后6
值的索引,并通过^{IIUC
相关问题 更多 >
编程相关推荐