假设我有以下简单的dataframe:
df_data=pd.DataFrame({'name':['ABC','ABC XYZ']})
要获得最后一个元素,我应用:
df_end= pd.DataFrame(df_data.name.str.split().str.get(-1), columns=['name'])
结果就是ABC。当名称长度小于2时,我希望得到None。我试过以下方法,但效果不佳:
df_end['name'] = df_data.name.str.split().apply(lambda x: x[-1] if len(x)>1)
我不应该得到ABC作为ABC的最后一个元素,但是我应该得到ABC XYZ中的XYZ 问题来源StackOverflow 地址:/questions/59381444/get-last-string-element-in-dataframe-column-conditional
我想你可以试试:
df_data['name'].str.extract('\s(\S+)$')
输出:
0
0 NaN
1 XYZ
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。