鱼C论坛

 找回密码
 立即注册
查看: 2093|回复: 19

[已解决]pandas报错:AttributeError: module 'pandas' has no attribute 'rename'

[复制链接]
发表于 2023-3-19 13:01:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
如题,我有个作业,要跑个数据,代码如下:
QQ截图20230319125615.png

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


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

运行结果如下:
QQ截图20230319125933.png

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

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

(我知道手动打开那个csv修改一下列名就好了,可以跑成功,我就是想知道为啥报错)
最佳答案
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'})。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-19 13:18:38 | 显示全部楼层    本楼为最佳答案   

回帖奖励 +10 鱼币

这个报错可能是由于使用了 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'})。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-19 14:24:44 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-19 14:25:02 | 显示全部楼层
不会,占个楼
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-19 14:28:38 | 显示全部楼层
鱼币
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-19 15:36:09 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-19 16:06:27 | 显示全部楼层

回帖奖励 +10 鱼币

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

不懂帮顶
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-19 16:09:40 | 显示全部楼层

回帖奖励 +10 鱼币

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2023-3-21 12:27:01 | 显示全部楼层
isdkz 发表于 2023-3-19 13:18
这个报错可能是由于使用了 pandas 版本较高导致的。在 pandas 的早期版本中,rename 函数是在 pandas 包中 ...


改了一下,这一步不报错了,但是好像并没有修改列名,ivol直接是空的,最后报错是类型不一致
5.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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


是改成 ivol = ivol.rename 不是 ivol = pd.DataFrame().rename
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-21 12:30:11 | 显示全部楼层
isdkz 发表于 2023-3-19 13:18
这个报错可能是由于使用了 pandas 版本较高导致的。在 pandas 的早期版本中,rename 函数是在 pandas 包中 ...

而且,这个调用是需要加()的,否则会报self错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-21 12:31:49 | 显示全部楼层
如默 发表于 2023-3-21 12:30
而且,这个调用是需要加()的,否则会报self错误

我写成 pandas.DataFrame.rename() 这样是让你用相应的类型调用,并不是让你直接用 pandas.DataFrame.rename()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-21 12:33:39 | 显示全部楼层
isdkz 发表于 2023-3-21 12:30
是改成 ivol = ivol.rename 不是 ivol = pd.DataFrame().rename


你确定?
6.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-21 12:34:45 | 显示全部楼层
isdkz 发表于 2023-3-21 12:31
我写成 pandas.DataFrame.rename() 这样是让你用相应的类型调用,并不是让你直接用 pandas.DataFrame.ren ...

额,没太明白
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-21 12:38:20 | 显示全部楼层
本帖最后由 isdkz 于 2023-3-21 12:40 编辑


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

  1. ivol = pd.read_csv('daily_ivol.csv')
  2. ivol.rename(columns = {'code': 'stkcd'}, inplace=True)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-21 13:31:00 | 显示全部楼层
isdkz 发表于 2023-3-21 12:38
因为 ivol 在前面被替换过了,你重新读入吧


结果如下: 7.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-21 13:38:19 | 显示全部楼层

不要那个赋值呀

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


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

评分

参与人数 1荣誉 +1 鱼币 +5 贡献 +1 收起 理由
如默 + 1 + 5 + 1 感谢楼主无私奉献!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-21 15:24:06 | 显示全部楼层
isdkz 发表于 2023-3-21 13:38
不要那个赋值呀

我这里写的是

🆗了,感谢老哥,真的非常感谢,再多问一句,这个ivol = ivol.rename 和ivol.rename 有啥区别啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-21 15:31:12 | 显示全部楼层
isdkz 发表于 2023-3-21 15:28
这个 ivol = ivol.rename 会把 rename 的返回值赋给 ivol,但是 rename 加了参数 replace=True 会直接修 ...

明白了,谢谢,非常感谢!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-20 06:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表