如默 发表于 2023-3-19 13:01:59

pandas报错:AttributeError: module 'pandas' has no attribute 'rename'

如题,我有个作业,要跑个数据,代码如下:


这一行
ivol = pd.rename(columns = {'code':'stkcd'}, inplace = True)

会报错:AttributeError: module 'pandas' has no attribute 'rename'

运行结果如下:


可是我pandas是安装了的,版本是1.5.3,python版本是3.9.13

网上找的说是重新安装pandas或者是有文件夹和问价名字是pandas,我都看了,没有这个问题

(我知道手动打开那个csv修改一下列名就好了,可以跑成功,我就是想知道为啥报错)

isdkz 发表于 2023-3-19 13:18:38

这个报错可能是由于使用了 pandas 版本较高导致的。在 pandas 的早期版本中,rename 函数是在 pandas 包中定义的,因此可以使用 pandas.rename() 的方式来调用该函数。但是,在较新的版本中,rename 函数已被移动到了 pandas.core.frame 模块中,因此需要使用 pandas.DataFrame.rename() 的方式来调用。

解决方法:

使用 pandas.DataFrame.rename():在代码中使用 pandas.DataFrame.rename() 函数来代替 pandas.rename() 函数。例如:df.rename(columns={'old_name': 'new_name'})。

liuhongrun2022 发表于 2023-3-19 14:24:44

liuhongrun2022 发表于 2023-3-19 14:25:02

不会,占个楼

歌者文明清理员 发表于 2023-3-19 14:28:38

鱼币

canfeng0522 发表于 2023-3-19 15:36:09

{:10_264:}

sfqxx 发表于 2023-3-19 16:06:27

本帖最后由 sfqxx 于 2023-3-19 16:08 编辑

不懂帮顶

贪吃蛇2 发表于 2023-3-19 16:09:40

{:7_146:}

如默 发表于 2023-3-21 12:27:01

isdkz 发表于 2023-3-19 13:18
这个报错可能是由于使用了 pandas 版本较高导致的。在 pandas 的早期版本中,rename 函数是在 pandas 包中 ...

改了一下,这一步不报错了,但是好像并没有修改列名,ivol直接是空的,最后报错是类型不一致

isdkz 发表于 2023-3-21 12:30:10

如默 发表于 2023-3-21 12:27
改了一下,这一步不报错了,但是好像并没有修改列名,ivol直接是空的,最后报错是类型不一致

是改成 ivol = ivol.rename 不是 ivol = pd.DataFrame().rename

如默 发表于 2023-3-21 12:30:11

isdkz 发表于 2023-3-19 13:18
这个报错可能是由于使用了 pandas 版本较高导致的。在 pandas 的早期版本中,rename 函数是在 pandas 包中 ...

而且,这个调用是需要加()的,否则会报self错误

isdkz 发表于 2023-3-21 12:31:49

如默 发表于 2023-3-21 12:30
而且,这个调用是需要加()的,否则会报self错误

我写成 pandas.DataFrame.rename() 这样是让你用相应的类型调用,并不是让你直接用 pandas.DataFrame.rename()

如默 发表于 2023-3-21 12:33:39

isdkz 发表于 2023-3-21 12:30
是改成 ivol = ivol.rename 不是 ivol = pd.DataFrame().rename

你确定?

如默 发表于 2023-3-21 12:34:45

isdkz 发表于 2023-3-21 12:31
我写成 pandas.DataFrame.rename() 这样是让你用相应的类型调用,并不是让你直接用 pandas.DataFrame.ren ...

额,没太明白

isdkz 发表于 2023-3-21 12:38:20

本帖最后由 isdkz 于 2023-3-21 12:40 编辑

如默 发表于 2023-3-21 12:34
你确定?

因为 ivol 在前面被替换过了,你重新读入吧

ivol = pd.read_csv('daily_ivol.csv')
ivol.rename(columns = {'code': 'stkcd'}, inplace=True)

如默 发表于 2023-3-21 13:31:00

isdkz 发表于 2023-3-21 12:38
因为 ivol 在前面被替换过了,你重新读入吧

结果如下:

isdkz 发表于 2023-3-21 13:38:19

如默 发表于 2023-3-21 13:31
结果如下:

不要那个赋值呀

我这里写的是
ivol = pd.read_csv('daily_ivol.csv')
ivol.rename(columns = {'code': 'stkcd'}, inplace=True)

你写的是
ivol = pd.read_csv('daily_ivol.csv')
ivol = ivol.rename(columns = {'code': 'stkcd'}, inplace=True)                # 这里的 ivol = 不要

如默 发表于 2023-3-21 15:24:06

isdkz 发表于 2023-3-21 13:38
不要那个赋值呀

我这里写的是


🆗了,感谢老哥,真的非常感谢,再多问一句,这个ivol = ivol.rename 和ivol.rename 有啥区别啊

isdkz 发表于 2023-3-21 15:28:33

如默 发表于 2023-3-21 15:24
🆗了,感谢老哥,真的非常感谢,再多问一句,这个ivol = ivol.rename 和ivol.rename 有啥区别啊

这个 ivol = ivol.rename 会把 rename 的返回值赋给 ivol,但是 rename 加了参数 replace=True 会直接修改原来的 dataframe,所以不需要赋值会给 ivol,因为 rename 的返回值是 None,你赋值给 ivol 的话,ivol 就变为 None 了,而不是原来的 dataframe

如默 发表于 2023-3-21 15:31:12

isdkz 发表于 2023-3-21 15:28
这个 ivol = ivol.rename 会把 rename 的返回值赋给 ivol,但是 rename 加了参数 replace=True 会直接修 ...

明白了,谢谢,非常感谢!
页: [1]
查看完整版本: pandas报错:AttributeError: module 'pandas' has no attribute 'rename'