python – 根据涉及len(string)给出KeyError的条件表达式从pandas DataFrame中删除行

我有一个pandas DataFrame,我想从中删除行,其中特定列中字符串的长度大于2.

我希望能够做到这一点(每this answer):

df[(len(df['column name']) < 2)]

但我得到错误

KeyError: u'no item named False'

我究竟做错了什么?

(注意:我知道我可以使用df.dropna()来删除包含任何NaN的行,但是我没有看到如何根据条件表达式删除行.)

解决方法:

当你执行len(df [‘column name’])时,你只得到一个数字,即DataFrame中的行数(即列本身的长度).如果要对列中的每个元素应用len,请使用df [‘column name’].map(len).所以试试吧

df[df['column name'].map(len) < 2]

相关文章

转载:一文讲述Pandas库的数据读取、数据获取、数据拼接、数...
Pandas是一个开源的第三方Python库,从Numpy和Matplotlib的基...
整体流程登录天池在线编程环境导入pandas和xrld操作EXCEL文件...
 一、numpy小结             二、pandas2.1为...
1、时间偏移DateOffset对象DateOffset类似于时间差Timedelta...
1、pandas内置样式空值高亮highlight_null最大最小值高亮背景...