Google Python编程风格指南中文翻译
5星 · 超过95%的资源 需积分: 9 34 浏览量
更新于2024-07-28
收藏 319KB PDF 举报
"GooglePython编程风格指南中文版"
Google Python编程风格指南是一份详细文档,旨在规范Python编程的代码风格,提升代码可读性和团队协作效率。这份指南由Google公司制定,并由li3pATyahoo.cn整理成中文版。指南涵盖了多个方面,包括语法、注释、类、字符串、异常处理、命名约定以及线程等。
1. **Python风格规范**
- **分号**: 不要在行尾使用分号,避免在同一行放置两条命令。
- **行长度**: 每行代码应不超过80个字符,但在某些情况下(如Python2.4及更早版本的导入语句)可以适当超过。
- **括号**:尽可能避免不必要的括号,但可以用来实现行连接,例如在长参数列表或字符串连接中。
2. **缩进**:使用4个空格进行缩进,不使用制表符,以保持一致性。
3. **空行**:在类定义之间、方法定义之间以及大段逻辑之间添加空行,以区分不同功能区域。
4. **空格**:合理使用空格增强代码可读性,如在操作符周围、逗号后、冒号前等地方。
5. **Python解释器**:建议使用最新稳定版本的Python解释器,以利用新特性并减少已知问题。
6. **注释**:使用清晰、简洁的注释,注明目的和工作原理,类的注释应包含文档字符串。
7. **类**:类名使用首字母大写的驼峰式命名法,避免在类名中使用下划线。
8. **字符串**:长字符串可以使用三引号或多行字符串,避免使用行连接符。
9. **TODO注释**:用于标记待完成的工作,格式为`# TODO(作者): 描述问题或待解决事项`。
10. **导入格式**:保持导入语句的整洁,一般分为标准库导入、第三方库导入和当前项目导入三类,每类之间空一行。
11. **语句**:避免使用复杂的嵌套结构,保持代码简洁。
12. **访问控制**:使用`_`前缀表示非公开成员,双下划线`__`表示私有成员。
13. **命名**:遵循PEP 8的命名规则,如变量小写加下划线,常量全大写等。
14. **Main**:在文件底部定义`if __name__ == '__main__':`,用于执行直接运行文件时的代码。
15. **Python语言规范**:遵循Python的官方语言规范,如避免使用已弃用的特性。
16. **pychecker**:推荐使用pychecker工具检查代码中的错误和警告。
17. **导入**:避免导入星号`*`,以防止名称冲突和隐藏错误。
18. **包**:正确组织代码,使用包结构管理模块。
19. **异常**:使用明确的异常类型,提供有用的异常消息。
20. **全局变量**:限制全局变量的使用,尽量保持作用域最小化。
21. **嵌套/本地/内部类或函数**:仅在必要时使用,以保持代码清晰。
22. **列表推导**:使用列表推导简化循环结构,提高代码效率。
23. **默认迭代器和操作符**:充分利用Python内置的迭代和操作符,如`in`、`not in`等。
24. **生成器**:使用生成器减少内存占用,优化性能。
25. **Lambda函数**:用于创建简短的匿名函数,但避免过度使用。
26. **默认参数值**:谨慎设置默认参数,避免副作用,如使用可变对象作为默认值。
27. **属性(properties)**:使用`@property`装饰器封装类的属性访问,确保数据安全。
28. **True/False的求值**:理解布尔值的计算规则,避免潜在的逻辑错误。
29. **过时的语言特性**:避免使用已被弃用的Python特性,如`exec`和`eval`。
30. **静态Scoping(Lexical Scoping)**:理解变量的作用域规则,避免意外的全局变量污染。
31. **函数与方法装饰器**:使用装饰器增强函数功能,如日志记录、性能测试等。
32. **线程**:在需要并发执行任务时,谨慎使用线程,注意GIL(全局解释器锁)的影响。
33. **威力过大的特性**:小心使用像`__slots__`、`__metaclass__`等高级特性,确保正确理解和使用。
Google Python风格指南提供了全面的指导,帮助开发者编写更加规范、易于阅读和维护的Python代码。遵循这些最佳实践,不仅可以提高代码质量,也有助于团队间的协作和项目的长期维护。
1593 浏览量
352 浏览量
2980 浏览量
2021-09-29 上传
191 浏览量
120 浏览量
281 浏览量
brian00002
- 粉丝: 0
- 资源: 72
最新资源
- 用友ERP-U8企业应用套件V860销售培训
- kab2wl-开源
- ProjectWeek1_Hangman_17
- quarkus-webassembly-jdk11:Quarkus 和 Webassembly(使用 Teavm)测试
- 新手-开发人员:白山问题解决
- VC++ 6.0.rar
- TStone-开源
- aip-java-sdk-4.11.1.jar包.zip
- 基于JavaWeb实现网上招标平台【系统+数据库】
- 工伤保险培训:工伤保险的概念及工伤保险基金
- alexxy:alexxy的一些随机进行中的工作
- bagi.me:BAGI.ME 是一个可以轻松快速地分享、捐赠或投票的平台。 由 Elclark 创建,作为一个附带纯 JavaScript 代码库并使用 Firebase 作为后端的项目
- app-icon.rar
- 客户经理制:组织、管理PPT
- JWebMSN-开源
- try_py_demo:leetcode算法题的python实现