python 调试技巧

简介: 文章说明编程过程中,出现BUG不可避免,所以经常要进行调试.在廖雪峰的python3教程中,有一篇专门讲调试的文章,简单列举了调试的几种方法,建议先进行阅读,了解一下。

文章说明

编程过程中,出现BUG不可避免,所以经常要进行调试.
廖雪峰的python3教程中,有一篇专门讲调试的文章,简单列举了调试的几种方法,建议先进行阅读,了解一下。

为更方便新手学习,我结合自身开发情况,进一步补充一下。

一.print大法

如果不是确定要记录到日志,一般用的最多的还是print。
print()内置函数,一般最初学习python的时候,就接触到了,这里再列举一下几种调试常用的print用法。

1.直接打印数字
print(111111111)

2.直接打印文字
print("进来了")

3.直接打印变量
print(name)

4.打印文字+变量
print("进来了"+name)

5.打印文字+变量
print("进来了" , name)

6.打印文字+变量
print("进来了,名字是%s,年龄是%d" % (name , age))

二.IDE断点调试

如图所示,为PyCharm的调试。
(注:图为网页分享,并非原创。找不到原图链接了,抱歉。)

img_2d37b16f09d1b36bfffd9dd2f5f86790.png

三.终极武器logging

python有一个标准库logging,用来管理日志。
通过整个标准库,可以进一步构建自己的日志模块。
如下是一个自定义的日志模板。
(注:整个模块是网友分享,并非原创。找不到原文链接了,抱歉。)

import time
import logging
from logging.handlers import TimedRotatingFileHandler
####################################
#日志级别大小关系为:CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET,当然也可以自己定义日志级别。

print_level = logging.DEBUG    #打印级别控制
file_path = "D:/TestDemo/"        #定义日志存放路径
file_name = time.strftime('%Y%m%d', time.localtime(time.time()))  #文件名称

####################################
class Log():
    # 构造函数
    def __init__(self, name):
        self.filename = file_path + file_name + '.log'  # 日志文件名称
        self.name = name  # 为%(name)s赋值

        #创建日志器
        self.logger = logging.getLogger(self.name)

        # 控制记录级别
        self.logger.setLevel(print_level)

        # 控制台日志
        self.console_handler   = logging.StreamHandler()
        console_format = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s[line:%(lineno)d] - %(message)s')
        self.console_handler.setFormatter(console_format)

        # 文件日志
        self.filetime_handler  = TimedRotatingFileHandler(self.filename, 'D', 1, 30) #保留30天,1月保存一个文件
        file_format = logging.Formatter('%(asctime)s - %(levelname)s - %(name)s[line:%(lineno)d] - %(message)s')
        self.filetime_handler.setFormatter(file_format)

        # 为logger添加的日志处理器
        self.logger.addHandler(self.console_handler)
        self.logger.addHandler(self.filetime_handler)

    #测试
    def debug(self, msg):
        self.logger.debug(msg)

    #信息
    def info(self, msg):
        self.logger.info(msg)

    #警告
    def warning(self, msg):
        self.logger.warning(msg)

    #错误
    def error(self, msg):
        self.logger.error(msg)

    #重大错误
    def critical(self, msg):
        self.logger.critical(msg)

    #抛出异常
    def exception(self, msg):
        self.logger.exception(msg)

    #关闭控制台日志
    def close_console(self):
        self.logger.removeHandler(self.console_handler)

    # 关闭文件日志
    def close_filetime(self):
        self.logger.removeHandler(self.filetime_handler)

本文如有帮助,敬请留言鼓励。
本文如有错误,敬请留言改进。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
2月前
|
开发框架 人工智能 Rust
Python 潮流周刊#12:Python 中如何调试死锁问题?
Python 潮流周刊#12:Python 中如何调试死锁问题?
16 0
|
2月前
|
监控 IDE 开发工具
Python中的日志记录与调试技巧
Python中的日志记录与调试技巧
|
3月前
|
存储 Shell 程序员
Python 自动化指南(繁琐工作自动化)第二版:十一、调试
Python 自动化指南(繁琐工作自动化)第二版:十一、调试
|
3月前
|
IDE 开发工具 Python
|
9月前
|
小程序 IDE Go
Python案例分析|使用调试器调试Python程序
本案例通过一个示例程序的调试,帮助大家了解使用Python调试器调试程序的方法 分析定位程序错误是程序设计最基本的功能。Python标准库的调试器pdb提供了基本的调试功能:设置断点、查看变量等。 集成开发环境(IDE,例如IDLE、Spyder、PyCharm)则提供了更直接方便的调试器。 本案例研究通过实例,阐述使用IDLE调试器跟踪调试Python程序的基本方法
118 1
Python案例分析|使用调试器调试Python程序
|
4月前
|
块存储 Python
rados 命令行函数 调试 ceph python
rados 命令行函数 调试 ceph python
30 0
|
5月前
|
NoSQL C++ Python
108 python高级 - 调试
108 python高级 - 调试
27 0
|
7月前
|
NoSQL Linux C++
Linux下使用命令行调试Python程序
Linux下使用命令行调试Python程序
252 0
Linux下使用命令行调试Python程序
|
8月前
|
IDE Shell Go
【100天精通python】Day18:python程序异常与调试_常用程序调试方式与技巧,如何将调试代码与正式代码分开
【100天精通python】Day18:python程序异常与调试_常用程序调试方式与技巧,如何将调试代码与正式代码分开
150 0

热门文章

最新文章