如何解决使用全局变量创建新的数据框
price
price
date
2010-01-04 34.57282657
2010-01-04 123.900000
2010-01-04 353.6789738
2010-01-04 13.08
2010-01-04 12.45
如何为下面列表中的每个项目创建一阶差分数据框?代码必须是通用的。 我尝试过:
listxx = ["price"]
for x in listxx:
globals().update({x_first_diff :x.diff().dropna()})
Expected Output:
price_first_diff
price_first_diff
2010-01-04
2010-01-04 89.33
...
解决方法
您快到了,只需再次使用globals
即可访问数据框,并使用格式化的字符串命名修改后的数据框:
listxx = ["price"]
for x in listxx:
globals().update({f'{x}_first_diff':globals()[x].diff().fillna('')})
price_first_diff
# price
#date
#2010-01-04
#2010-01-04 89.3272
#2010-01-04 229.779
#2010-01-04 -340.599
#2010-01-04 -0.63
您还可以尝试使用dict理解来创建新的数据框,然后更新globals
:
listxx = ["price"]
dc={f'{x}_first_diff' :globals()[x].diff().fillna('') for x in listxx}
globals().update(dc)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。