pandas 获取不符合条件的dataframe

search for “does-not-contain” on a dataframe in pandas

问题来源:做项目时,想拿到不符合条件的所有数据,比如:通话类型有好多种(主叫、被叫、呼转……),现在想分析所有非主叫数据,那么问题就来了。

方法一:df[~df.col.str.contains(word)]

>>> df = pd.DataFrame({"A": ["Hello", "this", "World", "apple"]})
>>> df.A.str.contains("Hello|World")
0     True
1    False
2     True
3    False
Name: A, dtype: bool
>>> ~df.A.str.contains("Hello|World")
0    False
1     True
2    False
3     True
Name: A, dtype: bool
>>> df[~df.A.str.contains("Hello|World")]
       A
1   this
3  apple

[2 rows x 1 columns]

注意:
- 似乎 df[~(df.A.str.contains("Hello") | (df.A.str.contains("World")))]比上面使用正则,速度会快点
- 获取“非”数据的条数:(~df.col3.str.contains('u|z')).sum()

方法二:

df[df["col"].str.contains('this'|'that')==False]
>>> df = pd.DataFrame({"A": ["Hello", "this", "World", "apple"]})
>>> df[df['A'].str.contains("Hello|World")==False]
       A
1   this
3  apple

# 多个条件情况下:
# df[df["col1"].str.contains('this|that')==False and df["col2"].str.contains('foo|bar')==True]

方法三:

>>> df = pd.DataFrame({"A": ["Hello", "this", "World", "apple"]})
>>> df['A'].str.contains(r'^(?:(?!Hello|World).)*$')
0    False
1     True
2    False
3     True
Name: A, dtype: bool
>>> df[df['A'].str.contains(r'^(?:(?!Hello|World).)*$')]
       A
1   this
3  apple

作者:Chihwei_hsu
来源:http://chihweihsu.com
Github:https://github.com/HsuChihwei

  • 4
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在使用pandas处理数据时,如果你想要删除DataFrame中符合特定条件的某一条行,可以使用条件筛选结合索引操作来实现。具体方法是先通过条件筛选出所有符合条件的行,然后使用索引访问其中的一行进行删除。由于直接删除单行可能会有多个结果,因此这里的关键是确保你能够精确地定位到某一行。 以下是一个基本的步骤说明: 1. 使用条件筛选出所有符合条件的行,并获取这些行的索引。 2. 确定你想要删除的具体哪一行。 3. 使用`.drop()`方法,并设置`axis=0`(表示删除行)和`inplace=True`(表示在原DataFrame上进行删除)。 这里提供一个简单的代码示例: ```python import pandas as pd # 假设有一个DataFrame df df = pd.DataFrame({ 'A': [1, 2, 3, 4], 'B': [5, 6, 7, 8] }) # 假设我们要删除列'A'中值为3的那一行 condition = df['A'] == 3 # 这个条件筛选出所有'A'列为3的行 rows = df[condition].index # 获取这些行的索引 # 如果有多行符合条件,你需要决定是删除第一行还是最后一行 # 例如,这里我们删除符合条件的第一行 if len(rows) > 0: df.drop(rows[0], inplace=True) # 删除第一行 else: print("没有符合条件的行可以删除。") ``` 注意,如果你的DataFrame很大,且存在多个符合条件的行,那么直接删除任意一个可能会导致无法精确控制删除哪一行。在这种情况下,你可能需要先对索引进行排序或者通过其他逻辑确定具体的行。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值