当前位置:   article > 正文

Python程序Run可以正常运行Debug运行报错(已解决)_python运行代码正常但是debug报错

python运行代码正常但是debug报错

1、问题描述


今天在PyCharm调试Python程序的时候,发现直接run可以正常运行,debug运行报错。

Debug运行报错内容:

Traceback (most recent call last):
File “D:\Program Files\Python310\lib\site-packages\numpy\core\getlimits.py”, line 687, in __init__
Self.dtype = numeric.dtype(int_type)
TypeError: ‘NoneType’ object is not callable
......
  • 1
  • 2
  • 3
  • 4
  • 5

报错方法:drop_duplicates()

于是写了一个简单的测试程序:

import pandas as pd
df = pd.DataFrame({'name': ['a', 'b', 'b'], 'age': [18, 20, 19]})
print(df)
df.drop_duplicates(subset=['name'], keep='first', inplace=True)
print(df)
  • 1
  • 2
  • 3
  • 4
  • 5
'
运行

1) 直接run运行该程序,程序正常输出,没有问题

在这里插入图片描述

2) debug运行该程序,发现报错内容与上述描述一致

在这里插入图片描述

2、 问题查找


通过查找资料,排查原因,尝试了网上各位大佬的很多建议:

1) 去掉调用函数后面(),注意!这是一个坑,这样可以不让程序报错,原因是这个函数就不执行了,当然不报错了!函数调用使用:函数名();不加()为函数对象

2)df.drop_duplicates(subset=[‘name’], keep=‘first’, inplace=‘True’)换成其他写法:

写法1:df = df.drop_duplicates(‘name’):未解决…

写法2:在该语句上面添加:

pd.set_option('display.max_columns', None)
pd.set_option('display.max_rows', None)
  • 1
  • 2

未解决…

写法3:考虑name列是否存在空值,在该语句上面添加:

df.fillna(0, inplace=True)
  • 1

未解决…

方法n:……

未解决…

3) 清除缓存:File->Invalidate Caches / Restart->Invalidate and Restart,并重启PyCharm,未解决…

在这里插入图片描述
4) 关掉Auto:File->settings->Build, Execution, Deployment->Python Debugger,未解决…

在这里插入图片描述
5) 编辑运行环境配置,未解决…

在这里插入图片描述
6) 其他:未解决…

3、 问题解决


最终摸着石头过河,尝试了以下方法,发现可以完美解决:

1) 关闭PyCharm(关闭项目),在本地项目路径下找到所有.idea文件删除

2) 打开PyCharm(打开项目),继续执行清除缓存:File->Invalidate Caches / Restart->Invalidate and Restart,并重启PyCharm

3) 打开终端(Windows PowerShell):依次执行如下命令(关键所在,1)、2)步可省略):

pip install --upgrade pip
pip install --upgrade numpy
pip install --upgrade pandas
  • 1
  • 2
  • 3

更新pip、numpy、pandas到最新版本

至此,再次debug运行上述程序,不再报错。完美解决!差点重装PyCharm重新克隆项目重新配置啦!


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/正经夜光杯/article/detail/894854
推荐阅读
相关标签
  

闽ICP备14008679号