加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 根据另一列中的值有条件地替换值

发布时间:2020-12-16 21:44:07 所属栏目:Python 来源:网络整理
导读:我有一个非常大的数据帧(~1.7MM行×6列).相关数据的简化示例如下: City BoroughBrooklyn BrooklynAstoria QueensAstoria UnspecifiedRidgewood UnspecifiedRidgewood Queens 所以我试图根据City列中的信息填充’Unspecified’值.例如,City Ridgewood在一个
我有一个非常大的数据帧(~1.7MM行×6列).相关数据的简化示例如下:
City        Borough

Brooklyn    Brooklyn
Astoria     Queens
Astoria     Unspecified
Ridgewood   Unspecified
Ridgewood   Queens

所以我试图根据City列中的信息填充’Unspecified’值.例如,City Ridgewood在一个实例中位于Unspecified Borough,但正确地将Borough列为数据集中其他地方的Queens.

我已经探索过Panda的补充,但它似乎不符合我的需求.我也考虑过np.where方法,但我不确定它在这种情况下是如何工作的.我对Pandas很新,但是地图/应用功能可能是我需要的吗?这可能可以通过一千种不同的方式实现,但是在寻找不会因数据大小而爬行的东西.

编辑:我能够创建一个字典,其中包含城市和行政区之间发生率最高的“对”,其代码如下:

specified = data[['Borough','City']][data['Borough']!= 'Unspecified']
paired = specified.Borough.groupby(specified.City).max()
paired = paired.to_dict()

配对的词典以城市为关键,自治市镇为价值.现在最后一步是将其应用/映射回行政区列……我该怎么做?

解决方法

这是一种方式:
>>> d
         City      Borough
0   Brooklyn     Brooklyn
1    Astoria       Queens
2    Astoria  Unspecified
3  Ridgewood  Unspecified
4  Ridgewood       Queens
>>> realData = d[d.Borough != "Unspecified"]
>>> realData = pandas.Series(data=realData.Borough.values,index=realData.City)
>>> d['Borough'] = d.City.map(realData)
>>> d
         City   Borough
0   Brooklyn  Brooklyn
1    Astoria    Queens
2    Astoria    Queens
3  Ridgewood    Queens
4  Ridgewood    Queens

这假设每个城市都有一个非未指定的自治市镇价值. (如果一个城市没有价值但是未指定,那么该行政区将显示为NA.)

编辑:如果你已经在你编辑的帖子中创建了你的词典,只需使用d [‘Borough’] = d.City.map(配对[‘Borough’])将每个城市从你的词典映射到自治市镇. map是一种有用的方法.它可以使用Pandas系列,使用dict或使用返回给定键的映射值的函数来映射值.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读