前题条件:环境不具备安装编译器条件,又需要调试python代码
例如:在仅安装terminal终端的服务器上进行开发调试代码,无法远程连接,没有桌面环境,留给你的只有terminal终端
方法一:使用python自带的pdb,无需额外安装地方包
示例代码 single_logger.py
# -*- coding: utf-8 -*-
import pdb
import logging
from concurrent_log_handler import ConcurrentRotatingFileHandler
def file_logger():
# 创建一个日志记录器对象
logger = logging.getLogger('MyLogger')
logger.setLevel(logging.INFO) # 设置日志级别
# 创建一个日志处理器,并设置日志文件路径、最大日志文件大小和备份文件数量
log_file = './logs/my_log.log'
file_handler = ConcurrentRotatingFileHandler(log_file, maxBytes=1024 * 1024 * 5, backupCount=5)
file_formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
file_handler.setFormatter(file_formatter)
logger.addHandler(file_handler)
return logger
if __name__ == '__main__':
logger = file_logger()
pdb.set_trace()
# 使用日志记录器
logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
pdb.set_trace()
logger.error('This is an error message')
logger.critical('This is a critical message')
运行以上代码,python3 single_logger.py
当代码遇到 set_trace() 时,会自动进入debug调试模式
单步调试:
n 或 next:执行下一行代码,如果遇到函数调用,则不会进入函数内部。
s 或 step:执行下一行代码,如果遇到函数调用,则会进入函数内部继续调试。
c 或 continue:继续执行直到遇到下一个断点或程序结束。
查看变量与表达式:
print、pprint、locals、globals
p 或 print:打印变量或表达式的值,如p result。
pp 或 pprint:格式化输出复杂的变量,如字典或列表。
l 或 locals:显示当前作用域内的所有局部变量及其值。
g 或 globals:显示全局作用域的所有变量及其值。
在调试过程中,可以通过set var_name value命令更改变量值。此外,可以使用r或return命令强制返回某个值,模拟函数提前结束。
set result 10:将result变量设为10。
return 10:在当前函数中立即返回10。
方法二:使用ipdb(pdb的进阶)
安装:piip3 install ipdb
使用:将方法一中的pdb替换成ipdb,其他不用改动。调试命令与pdb一致。唯一的区别,ipdb在调试的时候,会显示上下行,且不同类型代码会做颜色区分。分析代码更清晰
方法三:使用pudb(图形界面调试)
安装:pip3 install pudb
使用:将方法一中的pdb替换成pudb即可
首次使用会强制进行偏好配置,使用默认配置,ctrl+x退出设置
进入调试页面后,不再需要输入s、n、c进行调试,而是按对应按键后,直接生效对应操作。
按ctrl + x,可以进入编辑状态,对变量进行重新赋值,或增加新的变量进行调试。
非编辑模式下,按q退出调试。
总结:
以上调试包,可按需选择。
pdb为最基础的调试包,无需额外安装。主要用于没有外网安装第三方包的情况下,调试起来需要一定的技巧,对于调试深度较深的代码,使用起来不太方便。
ipdb,pdb的进阶版,主要在pdb的基础上添加了代码渲染和调试代码上下行展示功能。
pudb,目前terminal端显示最好的debug包,图形化调试页面非常友好,代码一目了然。