python 调试技巧
文章说明
编程过程中,出现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的调试。
(注:图为网页分享,并非原创。找不到原图链接了,抱歉。)
三.终极武器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)
本文如有帮助,敬请留言鼓励。
本文如有错误,敬请留言改进。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Python | 初识爬虫框架Scrapy
一、前言 今天给大家分享的是,Python里的爬虫框架Scrapy学习,包含python虚拟环境的搭建、虚拟环境的使用、Scrapy安装方法详解、Scrapy基本使用、Scrapy项目目录及内容基本介绍,let's go! 二、Python爬虫框架Scrapy简介 推荐查看Scrapy中文帮助文档: 1#维基百科看Scrapy 2''' 3Scrapy(SKRAY-pee)是一个免费和开源网络爬行框架Python编写的。最初设计用于Web抓取,它还可 4以用于使用API或作为通用Web爬网程序提取数据。它目前由网络抓取开发和服务公司ScrapinghubLtd.维护 5。 6Scrapy项目体系结构是围绕“Spider”构建的,它们是自包含的爬虫,可以获得一组指令。遵循其他框架的精 7神,不重复自己的框架,例如Django,
- 下一篇
Spring Boot 最佳实践(五)Spring Data JPA 操作 MySQL 8
一、Spring Data JPA 介绍 JPA(Java Persistence API)Java持久化API,是 Java 持久化的标准规范,Hibernate是持久化规范的技术实现,而Spring Data JPA是在 Hibernate 基础上封装的一款框架。 开发环境 Spring Boot 2.0.4 Spring Data JPA 2.0.4 MySQL 8.0.12 JDK 8 IDEA 2018.2 Windows 10 二、集成步骤 2.1 配置依赖 添加Spring Data JPA 和 MySQL Connector,配置pom.xml文件,代码如下: <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> <version>2.0.4.RELEASE</version> </dependency> &l...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Red5直播服务器,属于Java语言的直播服务器
- CentOS关闭SELinux安全模块
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS8编译安装MySQL8.0.19
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS8安装Docker,最新的服务器搭配容器使用
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Docker安装Oracle12C,快速搭建Oracle学习环境