删除pandas中包含某一字符的单元格

 待处理数据如下,含有两个‘—’

del_index=[]
for i in range(data.shape[0]):
    if data.iloc[i,:].isin(['—']).any():#每一行有任何一个单元格有'—'的话
        del_index.append(i)
data.drop(del_index,inplace=True)
data.to_excel(os.getcwd()+'/temp/2-2.xlsx')#保存文件

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Pandas,可以使用str.contains()方法来判断某一字符是否在单元格出现过。 例如: ``` import pandas as pd df = pd.DataFrame({'col1': ['hello', 'world', 'foo', 'bar']}) # 判断字符'o'是否在col1出现过 df['contains_o'] = df['col1'].str.contains('o') print(df) ``` 输出: ``` col1 contains_o 0 hello True 1 world True 2 foo True 3 bar False ``` 可以看到,contains_o列表示col1列的每个单元格是否包含字符'o',返回的是布尔值。 ### 回答2: 在使用pandas时,我们可以使用`str.contains()`方法来判断某一字符是否在单元格出现过。 首先,我们需要导入pandas库并读取数据: ```python import pandas as pd # 读取数据 df = pd.read_csv('data.csv') ``` 假设我们要判断字符'A'是否在列名为'column1'的单元格出现过,我们可以使用以下代码: ```python # 判断字符'A'是否在单元格出现过 df['column1'].str.contains('A') ``` 这将返回一个布尔值的Series对象,表示每个单元格是否包含字符'A'。 如果我们想要筛选出只包含字符'A'的,可以使用以下代码: ```python # 筛选只包含字符'A'的 result = df[df['column1'].str.contains('A')] ``` 以上代码将返回一个新的DataFrame对象,其包含在'column1'出现过字符'A'的。 综上所述,我们可以使用`str.contains()`方法来判断某一字符单元格是否出现过,并根据需要进相应操作。 ### 回答3: 在Pandas,我们可以使用`str.contains()`方法来判断某一字符是否在单元格出现过。这个方法可以用于Series和DataFrame对象。 对于Series对象,我们可以直接调用`str.contains()`方法来判断是否包含某一字符,并返回一个布尔值的Series。 例如,我们有一个Series对象`data`包含了一些字符数据,我们想要判断某一字符`'a'`是否在每个单元格出现过,可以使用以下代码: ```python result = data.str.contains('a') ``` `result`将返回一个包含了每个单元格是否包含字符`'a'`的布尔值的Series。 对于DataFrame对象,我们可以使用`applymap()`方法结合自定义的lambda函数来实现判断某一字符是否在每个单元格出现过。 例如,我们有一个DataFrame对象`df`,其的每个单元格包含了一些字符数据,我们想要判断某一字符`'b'`是否在每个单元格出现过,可以使用以下代码: ```python result = df.applymap(lambda x: 'b' in x) ``` `result`将返回一个与原DataFrame对象结构相同的数据框,其的每个单元格都表示对应位置是否包含字符`'b'`的布尔值。 综上所述,我们可以使用`str.contains()`方法和`applymap()`方法来判断某一字符Pandas单元格是否出现过。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

k54kdk

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值