我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python调试代码

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python调试代码

我在看一些开源的python项目时,需要知道各个类各个函数之间的调用关系才能看懂代码,因此我写了个方法来跟踪代码的调用过程

 

  1. import sys  
  2. from time import ctime  
  3. is_log=True 
  4.  
  5. def log_msg(msg,self=None,debug_file_name='/tmp/trace.log'):  
  6.         if is_log==False:  
  7.                 return 
  8.         try:  
  9.                 raise Exception  
  10.         except:  
  11.                 f = sys.exc_info()[2].tb_frame.f_back  
  12.                 fp = open(debug_file_name, 'a')  
  13.                 if self is None:  
  14.                     fp.write('['+ctime()+']<'+f.f_code.co_name+'>'+str(f.f_lineno)+':')  
  15.                 else:  
  16.                     fp.write('['+ctime()+']<'+self.__class__.__name__+'.'+f.f_code.co_name+'>'+str(f.f_lineno)+':')  
  17.                 fp.write(str(msg)+'\n')  
  18.                 fp.close() 

大家可以用这个调试方法进行跟踪调试

用法如下:

原型是:log_msg(msg,self=None,debug_file_name='/tmp/swift.log')

第一个参数是输出信息,

第二个参数是所在类,可省略,在类里使用的话填self即可。

第三个参数是输出的日志文件,默认为/tmp/swift.log

 

from swift.common.debuglog import log_msg

 

log_msg('start')

log_msg('start',self)

log_msg('start',self,'/tmp/abc.log')

 

输出内容:包括类名,函数名,行数,时间,输出信息

[Thu Jul 7 17:46:15 2011]<__init__>52:start

[Thu Jul 7 17:51:54 2011]<__init__>52:start

[Thu Jul 7 17:52:24 2011]<Swauth.__init__>52:start

[Thu Jul 7 17:57:18 2011]<Swauth.__init__>52:start

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python调试代码

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python调试代码

我在看一些开源的python项目时,需要知道各个类各个函数之间的调用关系才能看懂代码,因此我写了个方法来跟踪代码的调用过程 import sys  from time import ctime  is_log=True  def log_m
2023-01-31

#7 Python代码调试

前言Python已经学了这么久了,你现在已经长大了,该学会自己调试代码了!相信大家在编写程序过程中会遇到大量的错误信息,我也不例外的啦~遇到这些问题该怎么解决呢?使用最多的方法就是使用print打印中间变量了哇,关于这种方法怎么说呢~low
2023-01-31

Python代码调试技巧

原文地址:http://www.ibm.com/developerworks/cn/linux/l-cn-pythondebugger/一、使用pdb进行调试pdb是Python自带的包,为Python提供一种交互的源代码调试功能。常用命令
2023-01-31

python调试代码举例

Python自带的pdb库,发现用pdb来调试程序还是很方便的,当然了,什么远程调试,多线程之类,pdb是搞不定的。用pdb调试有多种方式可选:1. 命令行启动目标程序,加上-m参数,这样调用myscript.py的话断点就是程序的执行第一
2023-01-31

如何远程调试Python代码

这是一篇小记。平时使用python写的代码对外部依赖性都不复杂,这些代码在本地调试,运行没问题之后,就可以放到生产去跑了。然而,最近的一个项目,由于使用了一些内部服务,需要连接到内部的环境进行调试。如果每次都修改代码之后,发布一次到内部环境
2023-01-31

Linux下怎么调试python代码

本篇内容介绍了“Linux下怎么调试python代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Linux下调试pytho代码具体方法日志
2023-06-28

Unity3D代码调试

1.光标定位到代码中的指定行,按F9/单击左键 设置断点。 2.在点击RUN->“Attach to Process...”3.弹出Attach to Process面板出现的面板中选择Process Name为unity Editor(
2023-01-31

python怎么使用pdb调试代码

小编给大家分享一下python怎么使用pdb调试代码,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用pdb调试代码Python有自己的内置调试器-pdb。调试器
2023-06-27

vscode如何远程调试python代码

这篇文章主要介绍了vscode如何远程调试python代码的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vscode如何远程调试python代码文章都会有所收获,下面我们一起来看看吧。环境配置配置 python
2023-07-06

Python代码调试的方法是什么

这篇文章主要介绍“Python代码调试的方法是什么”,在日常操作中,相信很多人在Python代码调试的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python代码调试的方法是什么”的疑惑有所帮助!
2023-06-02

Node.js的代码调试debug

在Node.js中调试代码有多种方法,下面列举了一些常用的调试方法:1. 使用console.log():最简单的调试方法是在代码中使用console.log()语句输出变量的值或调试信息。这种方法适用于简单的调试场景,但对于复杂的程序可能
2023-09-17

Python 3 学习笔记:异常代码调试

什么是异常程序运行过程中,产生的错误统称为异常(bug)。这些异常有的可能是语法错误,如关键字输入错误、调用错误等,这一类的异常都是显式的,很好发现;还有一种就是隐式的错误,只用在使用时才会被发现,和使用者的操作有关。下面介绍一下 Pyth
2023-01-31

如何使用pdb进行python代码调试

这篇文章主要讲解了“如何使用pdb进行python代码调试”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用pdb进行python代码调试”吧!pdb为python程序实现了一个交互式调
2023-06-27

pycharm远程调试openstack代码

本文实例为大家分享了pycharm远程调试openstack的具体代码,供大家参考,具体内容如下 1.安装pycharm专业版 本文安装pycharm 2016.2.3专业版。网上教程较多,这里不做详细介绍,只要到pycharm官网上下载应
2022-06-04

如何使用Vim编写和调试Python代码

如何使用Vim编写和调试Python代码要想在Ubuntu下使用VIM编写和调试Python代码,请下安装如下的链接进行配置:https://segmentfault.com/a/1190000003962806 在安装过程中,可以遇到如下
2023-01-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录