首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >无法用字典更新Pandas dataframe元素

无法用字典更新Pandas dataframe元素
EN

Stack Overflow用户
提问于 2022-06-24 10:27:43
回答 2查看 36关注 0票数 0

我有一个Pandas dataframe,其中只有2列:第一列是名称,第二列是与名称相关的信息字典。添加新行很好,但是如果我尝试通过指定一个新字典来更新字典列,我将得到

代码语言:javascript
运行
复制
ValueError: Incompatible indexer with Series

所以,准确地说,这就是我为了产生错误而做的事情:

代码语言:javascript
运行
复制
import pandas as pd


df = pd.DataFrame(data=[['a', {'b':1}]], columns=['name', 'attributes'])
pos = df[df.loc[:,'name']=='a'].index[0]
df.loc[pos, 'attributes'] = {'c':2}

我找到了另一个可行的解决方案:

代码语言:javascript
运行
复制
import pandas as pd


df = pd.DataFrame(data=[['a', {'b':1}]], columns=['name', 'attributes'])
pos = df[df.loc[:,'name']=='a'].index[0]
df.loc[:,'attributes'].at[pos] = {'c':2}

但我希望得到一个答案,为什么第一种方法不起作用,或者我最初的做法是否有问题。

EN

Stack Overflow用户

发布于 2022-06-24 11:22:58

对我来说,在DataFrame.at工作

代码语言:javascript
运行
复制
df.at[pos, 'attributes'] = {'c':2}
print (df)
  name attributes
0    a   {'c': 2}
票数 0
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72742664

复制
相关文章

相似问题

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