Python 中报错 “TypeError: ‘list‘ object is not callable”的解决方法
问题:
用 list() 函数新建列表时,报错 “TypeError: ‘list’ object is not callable”。
原因:
一开始我找不到原因,因为我的代码和书上的例子是一模一样的,为什么会报错呢?后来在StackOverflow的一个问答 里找到了原因,因为之前的代码把list用于命名。我之前在定义一个列表时用了list=[1,2,3]
,后来觉得不妥,运行这行代码之后又删除了。但是 Jupyter Notebook 是交互式编辑器,除非重启kernel,一旦命名,这个变量就占用了内存。所以,后面调用 list() 函数运行代码list1=list(range(10))
时,编译器就把其中的list
解释为之前定义过的列表[1,2,3],程序运行出错。
解决方法:
1.千万不要用 list,tuple 等等 Python 的数据类型名来命名相应的对象,同理,不要用 for, in 这些关键词命名。
2.此时可以用 del list
,释放变量 list 占用的内存,这样再使用 list() 函数时就会正确解释。同时需要注意,之前定义名字为 list 的列表也已经不存在了。而如果在 Jupyter Notebook 遇到和我类似的情况,也可以重启kernel(也是在释放内存),然后运行 list() 函数所在代码单元。
附注:在上述 StackOverflow 的回答里,大神还提到了一种情况,比如,定义了一个列表:nums=[1,2,3]
,正常情况下,我们要用nums[i]
来索引元素。而如果用nums(i)
,也会报同样的错误:“TypeError: ‘list’ object is not callable”。
本文对您有帮助的话,请点赞支持一下吧,谢谢!
关注我 宁萌Julie,互相学习,多多交流呀!
参考:
https://stackoverflow.com/questions/31087111/typeerror-list-object-is-not-callable-in-python
相关文章
- 这些技术可能会阻碍你在大数据征程上的步伐
- 五个创建交互式图表的Python库
- 用Python侦测比特币交易的网络可视化分析
- Python内存问题:提示和技巧
- Python+大数据计算平台,PyODPS架构手把手教你搭建
- 大数据统一的批处理和流处理标准 Apache Beam
- 最好的Python机器学习库
- 一图简述大数据技术生态圈
- Python VS R语言?数据分析与挖掘该选哪一个?
- 大数据除了Hadoop,还有Scrapy
- 总结:常用的 Python 爬虫技巧
- 几分钟快速入门Python
- 用Python端对端数据分析识别机器人“僵尸粉”
- 用Python挖掘Twitter数据:数据采集
- 5招教你用Python构建好玩的深度学习应用
- Python树莓派编程2.7 总结
- Python树莓派编程第3章
- Python树莓派编程3.4.3 函数
- 机器人系统设计与制作:Python语言实现导读
- R、Python、Scala 和 Java,到底该使用哪一种大数据编程语言?