首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Python:不允许使用重叠的键和值进行替换

Python:不允许使用重叠的键和值进行替换
EN

Stack Overflow用户
提问于 2018-06-17 03:57:08
回答 1查看 3.9K关注 0票数 4

我尝试将输入数据帧中的值打乱,将这些新值存储到字典中,然后通过将输入数据框值替换为它们的字典映射来获得输出数据帧。

然而,我得到了“不允许替换重叠的键和值”的错误。

下面是我的代码示例:

代码语言:javascript
复制
in_df = ['A','B','C']
in_df = pd.DataFrame(in_df,columns=['Alphabets'])
df_temp = in_df.sample(frac=1).reset_index(drop=True)
df_temp = df_temp.rename(columns={'Alphabets':'sample'})
mask_dict = dict(zip(in_df['Alphabets'], df_temp['sample']))
out_df= in_df.replace({'Alphabets': mask_dict})

in_df如下所示:

代码语言:javascript
复制
Alphabets
A
B
C

mask_dict看起来像这样:

代码语言:javascript
复制
{'A': 'C', 'B': 'A', 'C': 'C'}

我希望out_df看起来像这样:

代码语言:javascript
复制
Alphabets
C
A
C

我找到了一种方法来做到这一点!

代码语言:javascript
复制
df_temp = in_df.stack().unique()
df_temp = pd.DataFrame(df_temp, columns=['Alphabets'])
df_temp1 = df_temp.sample(n=df_temp.size, random_state=123)
mask_dict = dict(zip(df_temp['Alphabets'], df_temp1['Alphabets']))
out_df = in_df.applymap(mask_dict.get)
EN

回答 1

Stack Overflow用户

发布于 2018-06-17 04:14:03

虽然我无法解释您的错误,但您可以使用pd.DataFrame.applymap

代码语言:javascript
复制
out_df = in_df.applymap(mask_dict.get)

这种方法也应该比pd.DataFrame.replace更有效,后者在与字典一起使用时会有很大的开销。

如果只需要替换单个序列中的值,则可以使用pd.Series.map

代码语言:javascript
复制
out_df = in_df.copy()
out_df['Alphabets'] = out_df['Alphabets'].map(mask-dict)

相关:Replace values in a pandas series via dictionary efficiently

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50891292

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档