大家好,欢迎来到 Crossin的编程教室 !
写代码,不可避免地会出现bug。很多人在初学编程的时候,当写完程序运行时,发现结果与自己预料中的不同,或者程序意外中止了,就一时没了想法,不知道该从何下手,只能反复重新运行程序,期待忽然有次结果就对了。
今天我就来分享一些代码遇到问题时的调试经验和解决技巧,希望对你有所帮助。
1. 读错误信息
来看如下一个例程:
import random
a = 0
for i in range(5):
b = random.choice(range(5))
a += i / b
print(a)
这个程序中,i 从 0 循环到 4,每次循环中,b 是 0 到 4 中的一个随机数。把 i / b 的结果累加到 a 上,最后输出结果。
运行这段程序,有时候会输出结果,有时候却跳出错误信息:
Traceback (most recent call last):
File "C:\Users\Crossin\Desktop\py\test.py", line 6, in <module>
a += i / b
ZeroDivisionError: integer division or modulo by zero
有些同学看见一段英文提示就慌了。其实没那么复杂,python的错误提示做得还是很标准的。
它告诉我们错误发生在test.py文件中的第6行
a += i / b
这一句上。
这个错误是“ZeroDivisionError”,也就是除零错。
“integer division or modulo by zero”,整数被0除或者被0模(取余数)。
因为0不能作为除数,所以当b随机到0的时候,就会引发这个错误。
知道了原因,就可以顺利地解决掉这个bug。
以后在写代码的时候,如果遇到了错误,先别急着去改代码。试着去读一读错误提示,看看里面都说了些啥。
2. 输出调试信息
我们在所有课程的最开始就教了输出函数“print”。它是编程中最简单的调试手段。有的时候,仅从错误提示仍然无法判断出程序错误的原因,或者没有发生错误,但程序的结果就是不对。这种情况下,通过输出程序过程中的一些状态,可以帮助分析程序。
把前面那个程序改造一下,加入一些与程序功能无关的输出语句:
import random
a = 0
for i in range(5):
print('i:', i)
b = random.choice(range(5))
print('b:', b)
a += i / b
print('a:', a)
print()
print(a)
运行后的输出结果(每次结果都会不一样):
i: 0
b: 3
a: 0.0
i: 1
b: 4
a: 0.25
i: 2
b: 0
Traceback (most recent call last):
File "C:\Users\Crossin\Desktop\py\test.py", line 8, in <module>
a += i / b
ZeroDivisionError: integer division or modulo by zero
当b的值为0时,发生了除零错。这次可以更清晰地看出程序出错时的状态。
在真实开发中,程序的结构可能会非常复杂。通过输出调试信息,可以有效地缩小范围、定位错误发生的位置,确认错误发生时的场景,进而找出错误原因。
还有其他一些调试技巧,如使用断点调试,借助IDE的错误提示等,可以参考我之前写过的文章:
另外,现在有了ChatGPT这种神器,也可以让它来辅助调试。这一方法在 Crossin 的新书《码上行动:零基础学会PYTHON编程(CHATGPT版)》中就有专门的介绍。
本书力求做到浅显易懂,让完全没有编程经验的零基础“小白”也能学会Python。内容从环境搭建这种最基础的步骤开始讲起,逐渐深入到常见的实际应用当中。在讲解知识点的同时配有相应的代码示例,让读者可以边学边练加深理解。
全书涵盖Python环境搭建、基础语法、常见数据类型、实用模块、正则表达式、面向对象编程、多任务编程等知识点。另外还提供了爬虫、GUI、游戏三个实战项目。
书中还创新地使用 ChatGPT 作为编程学习的辅助,带领读者探索AI时代下学习编程的新模式。
读者朋友们购买后可加入读者交流群,Crossin会为你开启陪读模式,解答你在阅读本书时的一切疑问。
感谢转发和点赞的各位~