改善Python程序的91个建议(笔记二)
接上篇,这里补充上书名(其实图片中已经有了)《编写高质量代码:改善Python程序的91个建议》。作者是 @赖勇浩 。这里我基本是按照书本上的东西在整理,时间有限没有深究。整理主要是为了方便自己以后查看,能帮助到一些人呢就更好了,如果因为水平问题有写错的部分,还请大家多多谅解。
【其实主要是整理了一下书中的标题,以及对个别建议的简单解释】
第四章:库
建议36:掌握字符串的基本用法
建议37:按需选择sort()和sorted()函数
》sort()是列表在就地进行排序,所以不能排序元组等不可变类型。
》sorted()可以排序任意的可迭代类型,同时不改变原变量本身。
建议38:使用copy模块深拷贝对象,区分浅拷贝(shallow copy)和深拷贝(deep copy)
建议39:使用Counter进行计数统计,Counter是字典类的子类,在collections模块中
建议40:深入掌握ConfigParser
建议41:使用argparse模块处理命令行参数
建议42:使用pandas处理大型CSV文件
》Python本身提供一个CSV文件处理模块,并提供reader、writer等函数。
》Pandas可提供分块、合并处理等,适用于数据量大的情况,且对二维数据操作更方便。
建议43:使用ElementTree解析XML
建议44:理解模块pickle的优劣
》优势:接口简单、各平台通用、支持的数据类型广泛、扩展性强
》劣势:不保证数据操作的原子性、存在安全问题、不同语言之间不兼容
建议45:序列化的另一个选择JSON模块:load和dump操作
建议46:使用traceback获取栈信息
建议47:使用logging记录日志信息
建议48:使用threading模块编写多线程程序
建议49:使用Queue模块使多线程编程更安全
第五章:设计模式
建议50:利用模块实现单例模式
建议51:用mixin模式让程序更加灵活
建议52:用发布-订阅模式实现松耦合
建议53:用状态模式美化代码
第六章:内部机制
建议54:理解build-in对象
建议55:__init__()不是构造方法,理解__new__()与它之间的区别
建议56:理解变量的查找机制,即作用域
》局部作用域
》全局作用域
》嵌套作用域
》内置作用域
建议57:为什么需要self参数
建议58:理解MRO(方法解析顺序)与多继承
建议59:理解描述符机制
建议60:区别__getattr__()与__getattribute__()方法之间的区别
建议61:使用更安全的property
建议62:掌握元类metaclass
建议63:熟悉Python对象协议
建议64:利用操作符重载实现中缀语法
建议65:熟悉Python的迭代器协议
建议66:熟悉Python的生成器
建议67:基于生成器的协程和greenlet,理解协程、多线程、多进程之间的区别
建议68:理解GIL的局限性
建议69:对象的管理和垃圾回收
后边还有2个章节的内容,分别是使用工具辅助项目开发、性能剖析与优化。
=============================================================
作者主页:笑虎(Python爱好者,关注爬虫、数据分析、数据挖掘、数据可视化等)
作者专栏主页:撸代码,学知识 - 知乎专栏
作者GitHub主页:撸代码,学知识 - GitHub
欢迎大家拍砖、提意见。相互交流,共同进步!
==============================================================
相关文章