最新不会现在才知道吧?Python终极调试指南——_在終端調試python(4),2024年最新网易测试开发面试题

现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。

分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

在这里插入图片描述
这就是开始将日志写入文件所需的全部操作,使用时,你可以通过

logging.getLoggerClass().root.handlers[0].baseFilename 找到文件的路径:

在这里插入图片描述
这种设置看起来似乎已经足够好了(通常是这样),

但是配置合理、格式清晰、可读性强的日志可以让你 Debug 起来更加轻松。

优化日志配置的一种方法是使用.ini 或.yaml 配置文件。

下面给你推荐一种配置示例:

在这里插入图片描述
在 python 代码中使用这种通用的配置将很难编辑和维护。

将配置内容保存在 YAML 文件中,

通过加载配置文件的形式,

我们就可以避免上述问题,

后续也可以很轻松地修改日志配置。

如果你想知道所有这些配置字段的含义,

可以查看这篇文档,它们中的大多数只是关键字参数,

如上面的示例所示。python学习交流群:903971231###

我们已经在配置文件中定义好了日志组件的相关配置,

接下来我们需要以某种方式加载该配置。

如果使用的是 YAML 配置文件,
在这里插入图片描述

最简单地加载配置的方法如下所示:

在这里插入图片描述
Python logger 实际上并不直接支持 YAML 文件,

但它支持字典配置,

可以使用 yaml.safe_load 从 YAML 文件轻松创建字典配置。

如果你倾向于使用.ini 文件,那么我只想指出,对于新应用程序,

很多文档都建议使用字典配置。

有关更多示例,可以查看使用手册。


使用日志装饰器

继续前面讲到的日志模块技巧。

你可能会遇到这么一种情况,

就是想 debug 函数调用执行的情况。

你可以使用日志装饰器,

无需修改函数主体代码即可实现:

在这里插入图片描述
说实话,

这可能需要花一些时间来装饰被调用函数(实际上,你需要做的仅仅是复制粘贴一下就好了)。

它的巧妙之处在于通过 log 函数设置参数,

并将参数用于内部 wrapper 函数。

然后,通过添加附加到装饰器的访问器函数使这些参数可调。

至于 functools.wraps 装饰器,

如果我们在这里不使用它,python学习交流群:903971231###

被装饰的函数的名称(func .name)将被装饰器的名称所覆盖。

在这里我们需要 functools.wraps 装饰器,

因为我们 debug 时要使用真实的函数名称。

它的原理是拷贝原始函数名称、函数文档描述以及参数列表到装饰器函数上。

下面就是上面代码的输出。看起来很整洁吧?

在这里插入图片描述


重写对象的 repr

可以在类中添加 repr 方法来改进一下代码,使其更易于调试。

它的功能就是返回类实例的字符串表示形式。

repr 方法的最佳实践是输出可用于重新创建实例的文本。

例如:

在这里插入图片描述
如果不希望或不能像上面那样表示对象,

另一个好的方法是使用<…>表示,

例如<_io.TextIOWrapper name=‘somefile.txt’ mode=‘w’ encoding=‘UTF-8’>。python学习交流群:903971231###

除了 repr 以外,重写 str 方法也是一个好方法,

该方法在使用 print(instance) 时被默认调用。

使用这两种方法,你只需打印变量即可获得很多信息。


重写字典类的 missing 方法

如果出于某种原因你需要实现自定义字典类,那么当你尝试访问实际上不存在的键时,可能会因 KeyErrors 引起一些错误。为了避免在 debug 代码时没有头绪,可以实现 missing 这一特殊方法,该方法在每次引发 KeyError 时都会被调用。

在这里插入图片描述
上面的实现非常简单,仅返回并记录缺少键的消息,但是你也可以记录其他有价值的信息,以便在代码出问题时给你提供更多上下文参考。


调试崩溃的应用程序

如果应用程序崩溃后你才有机会查看其中发生的情况,那么你可能会发现下面这个技巧非常有用。

你需要使用 -i 参数(python3 -i app.py)运行应用程序,该参数会使程序在退出后立即启动并进入交互式 shell。此时,你可以检查当前环境下的变量和函数。

如果这还不够好,那么你可以使用更厉害的 pdb,即 Python Debugger。pdb 具有很多功能,这些功能可以撰写一篇长文来介绍了。下面给出一个示例,我只摘抄了最重要的部分。首先让我们看一下崩溃的脚本:python学习交流群:903971231###

在这里插入图片描述
现在,如果我们使用 -i 参数运行它,我们将有机会对其进行调试:

在这里插入图片描述
上面的调试会话非常清晰地显示了可以使用 pdb 进行的操作。

程序终止后,我们进入交互式调试会话。

首先,我们导入 pdb 并启动调试器。

此时我们可以使用所有的 pdb 命令。

在上面的示例中,我们使用 p 命令打印变量,并使用 l 命令列出代码。

大多数时候,你可能希望设置断点,

文末有福利领取哦~

👉一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。img

👉二、Python必备开发工具

img
👉三、Python视频合集

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
img

👉 四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(文末领读者福利)
img

👉五、Python练习题

检查学习结果。
img

👉六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
img

img

👉因篇幅有限,仅展示部分资料,这份完整版的Python全套学习资料已经上传

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值