首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将Pandas列表列拆分为多个列

将Pandas列表列拆分为多个列
EN

Stack Overflow用户
提问于 2016-02-18 20:01:07
回答 10查看 358.5K关注 0票数 314

我有一个Pandas DataFrame,有一个专栏:

代码语言:javascript
运行
复制
import pandas as pd

df = pd.DataFrame({"teams": [["SF", "NYG"] for _ in range(7)]})

       teams
0  [SF, NYG]
1  [SF, NYG]
2  [SF, NYG]
3  [SF, NYG]
4  [SF, NYG]
5  [SF, NYG]
6  [SF, NYG]

如何将这一列列表分成两列?

预期结果:

代码语言:javascript
运行
复制
  team1 team2
0    SF   NYG
1    SF   NYG
2    SF   NYG
3    SF   NYG
4    SF   NYG
5    SF   NYG
6    SF   NYG
EN

回答 10

Stack Overflow用户

回答已采纳

发布于 2016-02-18 20:06:49

您可以将DataFrame构造函数与to_list创建的lists一起使用。

代码语言:javascript
运行
复制
import pandas as pd

d1 = {'teams': [['SF', 'NYG'],['SF', 'NYG'],['SF', 'NYG'],
                ['SF', 'NYG'],['SF', 'NYG'],['SF', 'NYG'],['SF', 'NYG']]}
df2 = pd.DataFrame(d1)
print (df2)
       teams
0  [SF, NYG]
1  [SF, NYG]
2  [SF, NYG]
3  [SF, NYG]
4  [SF, NYG]
5  [SF, NYG]
6  [SF, NYG]
代码语言:javascript
运行
复制
df2[['team1','team2']] = pd.DataFrame(df2.teams.tolist(), index= df2.index)
print (df2)
       teams team1 team2
0  [SF, NYG]    SF   NYG
1  [SF, NYG]    SF   NYG
2  [SF, NYG]    SF   NYG
3  [SF, NYG]    SF   NYG
4  [SF, NYG]    SF   NYG
5  [SF, NYG]    SF   NYG
6  [SF, NYG]    SF   NYG

为了一个新的DataFrame

代码语言:javascript
运行
复制
df3 = pd.DataFrame(df2['teams'].to_list(), columns=['team1','team2'])
print (df3)
  team1 team2
0    SF   NYG
1    SF   NYG
2    SF   NYG
3    SF   NYG
4    SF   NYG
5    SF   NYG
6    SF   NYG

使用apply(pd.Series)的解决方案非常慢:

代码语言:javascript
运行
复制
#7k rows
df2 = pd.concat([df2]*1000).reset_index(drop=True)

In [121]: %timeit df2['teams'].apply(pd.Series)
1.79 s ± 52.5 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)

In [122]: %timeit pd.DataFrame(df2['teams'].to_list(), columns=['team1','team2'])
1.63 ms ± 54.3 µs per loop (mean ± std. dev. of 7 runs, 1000 loops each)
票数 448
EN

Stack Overflow用户

发布于 2018-06-15 17:03:07

更简单的解决方案:

代码语言:javascript
运行
复制
pd.DataFrame(df2["teams"].to_list(), columns=['team1', 'team2'])

收益,

代码语言:javascript
运行
复制
  team1 team2
-------------
0    SF   NYG
1    SF   NYG
2    SF   NYG
3    SF   NYG
4    SF   NYG
5    SF   NYG
6    SF   NYG
7    SF   NYG

如果您想拆分分隔字符串的列而不是列表,也可以这样做:

代码语言:javascript
运行
复制
pd.DataFrame(df["teams"].str.split('<delim>', expand=True).values,
             columns=['team1', 'team2'])
票数 98
EN

Stack Overflow用户

发布于 2019-08-14 16:24:16

此解决方案保留df2 DataFrame的索引,不像任何使用tolist()的解决方案。

代码语言:javascript
运行
复制
df3 = df2.teams.apply(pd.Series)
df3.columns = ['team1', 'team2']

结果如下:

代码语言:javascript
运行
复制
  team1 team2
0    SF   NYG
1    SF   NYG
2    SF   NYG
3    SF   NYG
4    SF   NYG
5    SF   NYG
6    SF   NYG
票数 62
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35491274

复制
相关文章

相似问题

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