dataframe添加一列并迭代赋值_Pandas(DataFrame)如何把1列拆分为多列?

5ec4a6ce16893683e6d0b7f115fa3a82.png

今天更新了Anaconda2020.2,很多的包都随之更新了,是哪个包遇到了问题了呢?pandas,它更新到了1.0.1,之前使用的0.25。

数据格式为:

b0881dd9b633e3bbaaf9f4ac4960b38e.png
因为是部分数据,很多数据都是两个+号连接,所以是一列拆分三列

语句的写法为:

product_field['一级领域'],product_field['二级领域'],product_field['三级领域'] = product_field['v'].str.split('+',2).str

未来警告如下:

b15a5d974e232d02eb902ac3b8734141.png

未来警告:在以后的版本中,不推荐对字符进行列迭代。(百度翻译)

对这个警告,试验了三种修改方法:

方法一:

product_field 

方法二:

product_field = product_field['v'].str.split('+',2, expand = True).rename(columns={0:'一级领域', 1:'二级领域', 2:'三级领域'})

方法三:

product_field[['一级领域', '二级领域', '三级领域']] = product_field['v'].str.split('+', 2, expand = True)

我目前使用选择的是方法三,感觉既容易理解,代码也相对简洁,如果大家有很好的方法,欢迎一起讨论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值