2024年Python最新全面的『Python编码规范』_代码重构火葬场,2024年最新头条社招面试流程

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

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

二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

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

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

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

【强制+】【多写UT】

其他编程语言,同理。

有一份UT在手,重构起来,心里放心很多。

Python的话,只需要了解unittest就够了,pytest也可以。

【强制】【文件编码 & Unicode】:

  1. 使用 4 空格缩进,禁用任何 TAB 符号
  2. 源码文件使用 UTF-8 无 BOM 编码格式
  3. 总是使用 Unix \n 风格换行符
  4. 在每一个 py 文件头,都添加如下内容:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
 

# 只导入 future 空间的这两个特性就够了,其他特性容易造成其他方面的『不兼容』,没有使用的必要性。
from __future__ import (absolute_import, unicode_literals)

【强制】【命名】

  1. class,function 该如何命名,不赘述,严格照着PEP8做就行了,不用多想。
  2. 全局变量(全局变量,一般是常量,我们认为:凡是全局的,都是常量),应该始终使用全大写,如:
GLOBAL_PUBLIC = "G1"
_GLOBAL_PRIVATE = "G2"

**class** **Person**:
    _GLOBAL_IN_CLASS = 'G3'
    

按照这条要求,其实很多库**or**开源库,都是不符合要求的。为什么这么强硬呢?
Python中的变量定义,是不分『声明』、『定义』、『初始化』、『赋值』这几个概念的,所以一个
a = 1
如果没有上下文,你是很难确定其作用域的,也很难确定 这到底是初始化还是赋值(a已经存在过),
如果全局变量还不用全大写,带来的麻烦只会更多。

如果始终坚持这个原则,将会给代码的可读性带来极大提升。
  1. 定义枚举,始终加 Enum后缀;定义异常始终加Exception后缀;定义mixin,始终加Mixin后缀,如
**class** **DirectionEnum**:
    UP = 1
    DOWN = 2
    
    
**class** **MyException**(Exception):
    **pass**
**class** **MyError**(Exception):
    **pass**
    
**class** **SomeMixin**:
    **pass**

【强制】【强化private的概念】

即:最小知识原则,对外暴露的东西越少越好

翻译成大白话就是:
1. 实例属性,一般定义成private的
2. **class**,对外提供的方法越少越好
3. **module**,对外提供的接口越少越好
4. package,对外提供的 **module** 越少越好

翻译成代码就是:
1. 项目布局
package/
    __init_\_.py
    _private_mod.py
    public_mod.py    
    
2. 某模块内容
public_mod.py
PUBLIC_GLOBAL = 'G1'
_PRIVATE_GLOBAL = 'G2'
**class** **\_Class**:
    pass
**class** **PublicClass**:
    _PRIVATE_GLOBAL = 'G3'
    
    **def** **\_\_init\_\_**(**self**, name,age):
        **self**._name = name
        **self**._age = age
    **def** **public\_method**(**self**):
        pass
    **def** **\_private**(**self**):
        pass
        

所有东西,一开始就要定义成私有的,等到确实需要开放访问了,才开放出去。

【强制&重要】【关注公开接口的复杂性】

最好的接口是这样的,调用者无脑使用
**def** **interface**():
    **pass**
    
次等接口是这样的
**def** **interface**(param1):
    **pass**
    
次次等接口是这样的
**def** **interface**(p1, p2):
    **pass**

最大忍受限度的接口是这样的
**def** **interface**(p1, p2, p3='SOME DEFAULT'):
    **pass**
**def** **interface**(p1, *args):
    **pass**
    
不可接受的接口是这样的
**def** **interface**(p1, p2, **kwargs):
    **pass**

令人无语的接口是这样的
**def** **interface**(*args, **kwargs):  
# 尽量不要使用 \*\*kwargs, 某些流行库有这样的毛病,我是觉得:极大地增加了调用者的心理负担,反映了接口设计者的懒惰
    **pass**
    
一直觉得,**kwargs只适用于极少数明确的场合,并且需要辅以很明确的文档说明(解释为什么要使用),然而现实是,这个
特性已经被大家滥用了,有必要单独说明之。

在这里插入图片描述

感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:

① 2000多本Python电子书(主流和经典的书籍应该都有了)

② Python标准库资料(最全中文版)

③ 项目源码(四五十个有趣且经典的练手项目及源码)

④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)

⑤ Python学习路线图(告别不入流的学习)

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

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

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

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值