gpt4 book ai didi

python - 如何将 Pandas DataFrame 的每一列与其他列相乘?

转载 作者:行者123 更新时间:2023-11-30 23:13:36 24 4
gpt4 key购买 nike

给定一个 pandas 数据框,我想将每一列与其他列一一相乘,并将每个新列作为新列返回到该数据框。例如

A B C
1 2 3
2 4 4
1 2 5

然后

A B C A*B   A*C     B*C
1 2 2 2 3 6
2 4 8 8 8 16
1 2 2 2 5 10

最佳答案

以下是一种暴力方法,但它应该可以完成工作。 permutations() 生成所有列排列。内部的 sorted()set() 一起将 ('A','B')('B', 'A')

import pandas as pd
import itertools

df = pd.DataFrame([[1,2,1],[2,4,2],[3,4,5]],columns=['A','B','C'])

for c1,c2 in sorted(set([tuple(sorted(s)) for s in itertools.permutations(df.columns,2)])):
df['{0}x{1}'.format(c1,c2)] = df[c1]*df[c2]

print df

关于python - 如何将 Pandas DataFrame 的每一列与其他列相乘?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29229892/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com