我使用以下代码来规范化pandas数据框:
df_norm = (df - df.mean()) / (df.max() - df.min())
当所有列都是数字时,这可以正常工作。但是,现在我在df
中有一些字符串列,并且上面的规范化会出错。有没有办法只在数据帧的数字列上执行这种规范化(保持字符串列不变)?谢谢!
答案 0 :(得分:6)
您可以使用select_dtypes
计算所需列的值:
df = pd.DataFrame({'a': [1, 2, 3], 'b': ['a', 'b', 'c'], 'c': [4, 5, 6]})
df
a b c
0 1 a 4
1 2 b 5
2 3 c 6
df_num = df.select_dtypes(include=[np.number])
df_num
a c
0 1 4
1 2 5
2 3 6
然后你可以将它们分配回原来的df:
df_norm = (df_num - df_num.mean()) / (df_num.max() - df_num.min())
df[df_norm.columns] = df_norm
df
a b c
0 -0.5 a -0.5
1 0.0 b 0.0
2 0.5 c 0.5