将局部变量与pandas eval函数配合使用

发布于 2021-01-29 15:00:38

熊猫帮助文件说(用于eval): 为方便起见,可以使用多行字符串来执行多个分配。

但是,我发现这不适用于变量(使用ipython):

这有效:

df_price.eval("op = op * @mult", inplace = True)

但这不起作用(op,cl,hi,lo是数据帧df_price中的cols,其中mult是一个浮点数):

df_price.eval("""op = op * @mult
              cl = cl * @mult
              hi = hi * @mult
              lo = lo * @mult""", inplace = True)

错误: pandas.computation.ops.UndefinedVariableError未定义局部变量“ mult”

关注者
0
被浏览
79
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    我可以确认局部变量似乎仅适用于多行eval表达式的第一行。可能的解决方法:

    df_price.eval("""mult = @mult
                  op = op * mult
                  cl = cl * mult
                  hi = hi * mult
                  lo = lo * mult""", inplace = True)
    

    但是,这确实具有创建额外列的副作用。

    更新:

    我已经提交了具有此问题的修复程序的请求请求



知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看