python - 从循环中的字符串列表创建新的列名称

标签 python pandas

假设我在 pandas 中有以下列名称: [“A”,“B”]

我的问题是我想使用 for 循环从列表中获取列名称并创建一个新的列名称,其中包含列表中的部分元素。

在每次迭代中我想创建以下内容:

a = ["A", "B"]
for elements i in a:
    elements + "_c" = SOME FUNCTION column <df.elements>   

这应该会导致添加两个名为 A_c 和 B_c 的新列。

最佳答案

您可以使用Series.apply循环中:

a = ["A", "B"]
for i in a:
    df[i + "_c"] =  df[i].apply(SOME FUNCTION) 

或者DataFrame.applyadd_suffix对于新的 df 然后 join原文:

df1 = df[a].apply(SOME FUNCTION).add_suffix('_c')
df = df.join(df1)

示例:

df = pd.DataFrame({'A':[4,5,4,5,5,4],
                   'B':[7,8,9,4,2,3],
                   'C':[1,3,5,7,1,0]})

print (df)
   A  B  C
0  4  7  1
1  5  8  3
2  4  9  5
3  5  4  7
4  5  2  1
5  4  3  0

def FUNCTION(x):
    return x + 10

a = ["A", "B"]

for i in a:
    df[i + "_c"] =  df[i].apply(FUNCTION) 

print (df)
   A  B  C  A_c  B_c
0  4  7  1   14   17
1  5  8  3   15   18
2  4  9  5   14   19
3  5  4  7   15   14
4  5  2  1   15   12
5  4  3  0   14   13

df = df.join(df[a].apply(FUNCTION).add_suffix('_c'))
print (df)
   A  B  C  A_c  B_c
0  4  7  1   14   17
1  5  8  3   15   18
2  4  9  5   14   19
3  5  4  7   15   14
4  5  2  1   15   12
5  4  3  0   14   13

关于python - 从循环中的字符串列表创建新的列名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45250425/

相关文章:

python - 如何在 Pandas 中的超大数据帧上创建数据透视表

python带通滤波器-奇异矩阵误差

Python 字符串转十六进制字节

python - 我想更改 DataFrame (Python) 中的字符串值

python-3.x - 如何在列 Pandas 中找到连续零的最大计数?

python - Numpy - 在 Python 中创建一个输入为两个矩阵、输出为二进制矩阵的函数

python - 根据相应的 numpy 数组值分割 Dataframe

python - 使用 Facebook Prophet 同时预测多个变量

python - 使用Python的geopy + Google Maps Geocoding API的HTTP错误500

python - 如何将函数应用于 numpy 数组中的每个第三轴元素?