gpt4 book ai didi

python - 在pydatatable中扩展数据框时如何将f表达式列传递给函数?

转载 作者:行者123 更新时间:2023-12-04 15:25:53 24 4
gpt4 key购买 nike

我正在尝试生成一些随机数据并将其保存在数据表中,因此我创建了一个自定义函数:

def make_data(nrows):

DT = dt.Frame({'x': 5*np.random.normal(size=nrows)})

DT_EX = DT[:,f[:].extend({'y': 0.01*f['x'] + 0.1*np.random.normal(size=nrows)})]

return DT_EX


在执行此函数时,它返回一个 DT:
In [3]: make_data(5)                                                                                                                                                                                        
Out[3]:
| x y
-- + --------- ----------
0 | -0.486592 0.227217
1 | -1.90302 -0.0509506
2 | 4.69407 0.0758279
3 | -7.08778 -0.152139
4 | 0.917043 -0.204939


我想在 y 列表达式中添加一个 np.sin 函数,如下所示:
def make_data_version_two(nrows):

DT = dt.Frame({'x': 5*np.random.normal(size=nrows)})

DT_EX = DT[:,f[:].extend({'y': np.sin(f.x) + 0.01*f.x + 0.1*np.random.normal(size=nrows)})]

return DT_EX

在执行这个函数时,它抛出一个错误:
AttributeError                            Traceback (most recent call last)
<ipython-input-5-81a67037f9f1> in <module>
----> 1 make_data_version_two(5)

<ipython-input-4-e532306680bb> in make_data_version_two(nrows)
3 DT = dt.Frame({'x': 5*np.random.normal(size=nrows)})
4
----> 5 DT_EX = DT[:,f[:].extend({'y': np.sin(f.x) + 0.01*f['x'] + 0.1*np.random.normal(size=nrows)})]
6
7 return DT_EX

AttributeError: 'Expr' object has no attribute 'sin'


我的问题是如何将数据表列传递给任何其他函数,如 np.sin(f.x) 或 np.round(f.x) 等。

我也尝试过这些变体,但都没有奏效。
  • np.sin(f['x'])
  • np.sin(['x'])
  • 最佳答案

    是的,明白了。我查看了数据表 数学模块功能,并创建了一个新函数作为

    def make_data_version_three(nrows):

    DT = dt.Frame({'x': 5*np.random.normal(size=nrows)})

    DT_EX = DT[:,f[:].extend({'y': dt.math.sin(f.x) + 0.01*f['x'] + 0.1*np.random.normal(size=nrows)})]

    return DT_EX

    所以在这里我从数据表中导入了一个数学模块,从数学中我称之为 sin 函数
    dt.math.sin(f.x)


    输出:
    In [8]: make_data_version_three(5)                                                                                                                                                                          
    Out[8]:
    | x y
    -- + --------- ---------
    0 | -13.8865 -1.11732
    1 | -2.21624 -0.809127
    2 | -1.84779 -1.0217
    3 | 5.42131 -0.659641
    4 | 4.77623 -1.04619

    [5 rows x 2 columns]


    这里推荐通过datatable的math模块

    关于python - 在pydatatable中扩展数据框时如何将f表达式列传递给函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62243502/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com