首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >熊猫-包含列表的合并行

熊猫-包含列表的合并行
EN

Stack Overflow用户
提问于 2019-02-10 11:30:29
回答 1查看 687关注 0票数 0

我想合并行(按类型分组),但也要合并它们的列数据,在我的例子中,列数据由一个列表组成。

例如,我的数据如下:

代码语言:javascript
复制
Col1 Col2
a    [1,2,3]
a    [3,4,5]
b    [1,2,3,4,20]
b    [3,80,4,5]

最终得到的数据将是:

代码语言:javascript
复制
Col1 Col2
a    [1,2,3,4,5]
b    [1,2,3,4,20,80,5]
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-02-10 12:04:13

您可以使用群比

代码语言:javascript
复制
df = pd.DataFrame({'col1': ['a','a','b','b'], 'col2': [[1,2,3], [3,4,5],[1,2,3,4,20], [3,80,4,5]]})
print(df.groupby('col1').sum())

输出:

代码语言:javascript
复制
                               col2
col1                               
a                [1, 2, 3, 3, 4, 5]
b     [1, 2, 3, 4, 20, 3, 80, 4, 5]

如果只需要考虑重复值一次,则可以通过以下两种方式进行:

1)使用Set()

代码语言:javascript
复制
print(df.groupby('col1').sum()['col2'].apply(lambda x: list(set(x))).reset_index())

输出:

代码语言:javascript
复制
  col1                     col2
0    a          [1, 2, 3, 4, 5]
1    b  [1, 2, 3, 4, 5, 80, 20]

2) 通过使用dict.fromkeys(): --这将有助于保持列表中元素的顺序:

代码语言:javascript
复制
print(df.groupby('col1').sum()['col2'].apply(lambda x: list(dict.fromkeys(x))).reset_index())

输出:

代码语言:javascript
复制
  col1                     col2
0    a          [1, 2, 3, 4, 5]
1    b  [1, 2, 3, 4, 20, 80, 5]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54615918

复制
相关文章

相似问题

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