gpt4 book ai didi

python - 如何使用 Pandas 交换列中的两个(字符串)值

转载 作者:太空宇宙 更新时间:2023-11-04 04:16:41 24 4
gpt4 key购买 nike

我正在尝试同时 replace pandas df 中的值。对于下面的 df,我可以将 X 替换为 Y,反之亦然。但我必须同时这样做。如果我尝试将其作为单独的函数来执行,结果显然会将所有内容交换为最终函数。

import pandas as pd

d = ({
'Col' : ['X','Y','X','Y','X'],
})

df = pd.DataFrame(data=d)

df['Col'] = df['Col'].replace(['X'], 'Y')
df['Col'] = df['Col'].replace(['Y'], 'X')

print(df['Col'])

0 X
1 X
2 X
3 X
4 X

预期输出:

0    Y
1 X
2 Y
3 X
4 Y

最佳答案

这是一个已知问题(我认为是设计状态)- swapping string values with replace results in counter-intuitive behaviour.

在这种情况下,我的建议是使用 map 进行元素明智的替换。

df['Col'].map({'X': 'Y', 'Y': 'X'})

0 Y
1 X
2 Y
3 X
4 Y
Name: Col, dtype: object

如果还有其他可能的值,而您只是交换两个值,请添加一个 fillna 调用:

df['Col'].map({'X': 'Y', 'Y': 'X'}).fillna(df['Col'])

0 Y
1 X
2 Y
3 X
4 Y
Name: Col, dtype: object

关于python - 如何使用 Pandas 交换列中的两个(字符串)值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55273124/

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