Lin_Cainiaoyige 2021-08-16 12:35 采纳率: 71.4%
浏览 45
已结题

Python Dataframe 元素组合问题

我现在有一个Dataframe

df = pd.DataFrame({'a':['A','A','A','A','B','B','B','C','C','C','D','D'],
'b':['a','b','c','d','a','b','c','a','b','c','a','d']}

img

我想要做到基于A列的,B列的元素两两组合
得到如下结果

img

  • 写回答

1条回答 默认 最新

  • CSDN专家-HGJ 2021-08-16 13:33
    关注

    借助于itertools中的combination函数,获取a,b,c,d两两组合。然后转换一下就可以了。

    import pandas as pd
    from itertools import combinations
    df = pd.DataFrame({'a':['A','A','A','A','B','B','B','C','C','C','D','D'],
    'b':['a','b','c','d','a','b','c','a','b','c','a','d']})
    a=list(combinations(['a','b','c','d'],2))*2
    df.b=[x[0]+','+x[1] for x in a]
    print(df)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月24日
  • 已采纳回答 8月16日
  • 创建了问题 8月16日