Python:使用函数引用 DataFrame 中的列

问题描述

这是我拥有的代码

.......

gender = data.loc[np.where(data['ID']==id)]["gender"].tolist()[0]
cell = data.loc[np.where(data['ID']==id)]["cell"].tolist()[0]
bloodtype = data.loc[np.where(data['ID']==id)]["bloodType"].tolist()[0]

expList = tempPos[(tempPos.gender == gender) & (tempPos.cell == cell) & (tempPos.bloodType == bloodtype)]

.......

现在还有其他几列可以在 tempPos 数据框中引用(在上面的示例中,我使用了性别、细胞和血型)

有没有办法定义一个函数并动态引用列?

def generateProbability(col1,col2,col3):
    .......
    col1val = data.loc[np.where(data['ID']==id)][col1].tolist()[0]
    col2val = data.loc[np.where(data['ID']==id)][col2].tolist()[0]
    col3val = data.loc[np.where(data['ID']==id)][col3].tolist()[0]
    expList = tempPos[(tempPos.col1 == col1val) & (tempPos.col2 == col2val) & (tempPos.col3 == col3val)]
    ........

generateProbability("Age","Gender","bloodType")

谢谢。

解决方法

您无需创建函数。您可以通过 for 循环访问它们。

column_outputs = dict    # Dictionary to hold column outputs.

for column in data.columns:
    column_outputs[column] = data.loc[data['ID'] == id,column].tolist()[0]

column_outputs 现在应该包含每列所需的值,您可以使用列名作为键来访问这些值。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...