Python中文
首页
教程
问答
标签
搜索
登录
注册
Python&Pandas:遍历行以设置值
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>在我的<code>dataframe</code>中,我有一个包含<code>json/dict</code>的列,我希望遍历行以提取一些值,并将其添加到新列中。 数据如下所示,注意<code>omdb</code>是<code>dict</code> <a href="https://i.stack.imgur.com/Fj3TH.png" rel="nofollow noreferrer"><img src="https://i.stack.imgur.com/Fj3TH.png" alt="enter image description here"/></a></p> <p>我正在这样做,将<code>imdbRating</code>提取到一个独立的列中,但是它给了我<code>keyerror</code></p> <pre><code>pd_data['imdbRating'] = 0 for index, row in pd_data.iterrows(): row['imdbRating'] =row['omdb_info']['imdbRating'] </code></pre> <p>那么,提取价值的正确方法是什么?在</p> <p>另外,我可以让它工作:</p> ^{pr2}$ <p>更新: 现在我认为应该是数据问题,也许有些<code>row['omdb_info']</code>没有{<cd8>}?或者根本没有<code>row['omdb_info']</code>,我如何搜索它的存在?在</p> <pre><code># this work for index, row in pd_data[:118].iterrows(): pd_data.ix[index,'imdbRating'] = row['omdb_info']['imdbRating'] # this do not work for index, row in pd_data[:119].iterrows(): pd_data.ix[index,'imdbRating'] = row['omdb_info']['imdbRating'] print pd_data.ix[118]['omdb_info']['imdbRating'] # => 6.8 print pd_data.ix[119]['omdb_info']['imdbRating'] # => 6.9 print pd_data.ix[120]['omdb_info']['imdbRating'] # => 5.5 </code></pre> <p>它报告的错误</p> <pre><code>KeyError Traceback (most recent call last) <ipython-input-143-a0ae169ddfe9> in <module>() 9 # this do not work 10 for index, row in pd_data[:119].iterrows(): ---> 11 pd_data.ix[index,'imdbRating'] = row['omdb_info']['imdbRating'] KeyError: 'imdbRating' </code></pre> <p>另外,我可以在哪里上传数据文件,这样你就可以看一下了?在</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>我相信,您可以尝试简单地访问<code>omdb_info</code>中字典的值,并使用单个操作将其添加到新列中,而不是迭代。在</p> <pre><code>pd_data['imdb_rating'] = pd_data['omdb_info']['imdbRating'] </code></pre> <p>我相信对于您正在尝试的操作,您可能不需要迭代,但我承认我已经有一段时间没有使用数据帧了。在</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
4 回答
尽管python中的表达式为false,但循环仍在运行
9 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
1 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
10 回答
尽管python字典包含了大量的条目,但它并没有增长
9 回答
尽管python说模块存在,为什么我会得到这个消息?
5 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
5 回答
尽管stdout和stderr重定向,但未捕获错误消息
5 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
8 回答
尽管tkinter上的变量已更改,但显示未更改
4 回答
尽管try/except使用Python进行单元测试时出现断言错误
8 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
5 回答
尽管url有效,Pandas仍读取url的\u csv错误
5 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
9 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
7 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
2 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
1 回答
尽管下载了i,但找不到型号“fr”
2 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
10 回答
尽管为所有行指定了权重,网格(0)仍不起作用
3 回答