[英]How to apply function to two columns of Pandas dataframe and two if fucntion
我想创建一个基于收缩压和舒张压的类。 我有df
,其中包含Systolic
和Diastolic
列。 我定义了一个函数:
f = lambda x, y : my_function_expression.
现在我想在F适用于df
的两列Systolic
和Diastolic
对创建新列一类Blood_Pressure
,有点像:
df['Blood_Pressure'] = df['Systolic', 'Diastolic'].apply(lambda x, y : 0 if x >=90 and x <=120 and y >=60 and y <=80 else 1)
怎么做? 还有其他方法吗?
我想要的结果示例:
通常,在使用数据框时,您应该避免apply
并尝试根据特征(列)来考虑您的数据。 Pandas 确实提供了许多矢量化操作,而apply
没有。
你的情况,你可以做between
:
df['Class'] = (df['Systolic'].between(90,120) &
df['Distolic'].between(60,80)
).astype(int)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.