现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到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所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
👉二、Python必备开发工具
👉三、Python视频合集
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
👉 四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(文末领读者福利)
👉五、Python练习题
检查学习结果。
👉六、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
👉因篇幅有限,仅展示部分资料,这份完整版的Python全套学习资料已经上传
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!