根据可能不存在于所有值上的分隔符将pandas列拆分为两个

时间:2017-03-04 21:04:20

标签: python pandas split

我的数据框的其中一列看起来像这样:

[application]
blah/3.14
xyz/5.2
abc
...
...

(代表软件/版本)

我正在努力实现这样的目标:

[application] [name]  [ver]
blah/3.14      blah    3.14
xyz/5.2        xyz     5.2 
abc            abc     na   <-- this missing value can be filled in with a string too
...  
...

正如您已经知道的那样,我想将列拆分为两个,使用'/'作为分隔符。堆栈溢出解决方案建议如下:

tmptbl = pd.DataFrame(main_tbl.application.str.split('/', 1).tolist(), columns= ['name', 'ver'])
main_tbl['name'] = tmptbl.name
main_tbl['ver'] = tmptbl.ver

一开始看起来很棒,但是没有'/'的列会崩溃,例如'abc'。

我还能尝试什么?

1 个答案:

答案 0 :(得分:2)

使用带有参数expand=True的{​​{3}}返回DataFrame

main_tbl[['name','ver']] = main_tbl.application.str.split('/', expand=True)
print (main_tbl)
  application  name   ver
0   blah/3.14  blah  3.14
1     xyz/5.2   xyz   5.2
2         abc   abc  None

如果需要NaN添加str.split

main_tbl.ver = main_tbl.ver.replace({None:np.nan})
print (main_tbl)
  application  name   ver
0   blah/3.14  blah  3.14
1     xyz/5.2   xyz   5.2
2         abc   abc   NaN