首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何删除上次出现在Dataframe中的字符后的所有内容?

如何删除上次出现在Dataframe中的字符后的所有内容?
EN

Stack Overflow用户
提问于 2016-05-28 11:40:51
回答 2查看 3.9K关注 0票数 4

我有一个如下所示的dataframe DF (这是一个示例):

代码语言:javascript
复制
    EQ1                    EQ2                       EQ3
0   Apple.fruit            Oranage.eatable.fruit     NaN
1   Pear.eatable.fruit     Banana.fruit              NaN
2   Orange.fruit           Tomato.eatable            Potato.eatable.vegetable
3   Kiwi.eatable           Pear.fruit                Cabbage.vegetable
<And so on.. It is a large Dataframe>

我想删除之后的所有--在DF的每个元素中最后一次出现点. --并以不同的名称保存它,比如df_temp

期望输出:

代码语言:javascript
复制
   EQ1               EQ2                 EQ3
0   Apple            Oranage.eatable     NaN
1   Pear.eatable     Banana              NaN
2   Orange           Tomato              Potato.eatable
3   Kiwi             Pear                Cabbage
<And so on>

这就是我尝试过的:df_temp=".".join(DF.split(".")[:-1])

不幸的是,这似乎只适用于字符串,而不是Dataframe。我需要稍微调整一下这条线才能达到我想要的目的吗?谁来帮帮忙!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-05-28 13:39:44

你可以这样做:

代码语言:javascript
复制
df_temp = df.apply(lambda x: x.str.split('.').str[:-1].str.join('.'))

产出:

代码语言:javascript
复制
            EQ1              EQ2             EQ3
0         Apple  Oranage.eatable             NaN
1  Pear.eatable           Banana             NaN
2        Orange           Tomato  Potato.eatable
3          Kiwi             Pear         Cabbage   

string method docs

票数 8
EN

Stack Overflow用户

发布于 2016-05-28 13:42:29

你可以用提取物。

代码语言:javascript
复制
df_temp = df.apply(lambda x: x.str.extract(r'.*\.([^\.]*)', expand=False))

df_new = df.apply(lambda x: x.str.extract(r'(.*)\.[^\.]*', expand=False))

df_temp看起来像:

代码语言:javascript
复制
       EQ1      EQ2        EQ3
0    fruit    fruit        NaN
1    fruit    fruit        NaN
2    fruit  eatable  vegetable
3  eatable    fruit  vegetable

df_new看起来像:

代码语言:javascript
复制
            EQ1              EQ2             EQ3
0         Apple  Oranage.eatable             NaN
1  Pear.eatable           Banana             NaN
2        Orange           Tomato  Potato.eatable
3          Kiwi             Pear         Cabbage
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37498537

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档