如何解决使用iloc功能遍历数据框
我是python的新手。我希望使用循环将结果插入到使用iloc的列的每个单元格中,但是我不知道为什么除了“ 100000”输出以外,这些列只返回了nan。如果可能,请告知。非常感谢。
for i in range(data.shape[0]):
data['Money'] = np.nan
data['Money'].iloc[0] = 100000
data['Numbers of things'] = np.nan
data['Numbers of things'].iloc[i] = data['Money'].iloc[i] / (data['perspectives'].iloc[i] * 100)
解决方法
您不需要循环。您可以整体创建列:
data['Money'] = np.nan
data['Money'].iloc[0] = 100000
data['Numbers of things'] = data['Money'] / (data['perspectives'] * 100)
请注意,“ Money”列中除第一行外的所有行在构造上均为NaN。
编辑:
如果要使用其他列的前几行中的值填充一列,则可以使用.shift(1)
方法将列移位一行>
df = pd.DataFrame({'a': [1,2,3],'b': [2,3]})
df['c']=df['a'].shift(1) - df['b'].shift(1)
df
a b c
0 1 2 NaN
1 2 2 -1.0
2 3 3 0.0
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。