引子
今年开始,我在翻译一本大部头的,比较经典的的Python进阶书籍。
有空就翻译几页。这本书不仅是教你很多进阶的Python的语法,更重要的是讲解很多设计方法和设计思想。
这些方法和思想,一点点叠加起来,就会让你从一个普通的程序员变成一个很专业的程序员。至少看起来挺唬人的!
昨天我在翻译关于docstring的章节。书中举的一个例子,把一个很普通的类,转变成了跟Python内置的库一样专业的代码。
我感觉眼睛一亮,觉得有必要跟大家分享一下。
设计需求
这个类的功能很简单:
- 类名Point,代表二维坐标系中的一个点。
- 属性:x和y代表二维坐标
- 方法:类包含3个方法,实现了“回到原点”,“移动到指点的点”,“计算两个点之间的距离”。
想想看,你会怎么写呢?
专业级的代码
我就直接分享我认为比较专业的代码吧,请仔细阅读,品味其中专业的地方:
class Point:
"""
Represents a point in two-dimensional geometric coordinates
>>> p_0 = Point()
>>> p_1 = Point(3, 4)
>>> p_0.calculate_distance(p_1)
5.0
"""
def __init__(self, x: float = 0, y: float = 0) -> None:
"""
Initialize the position of a new point. The x and y
coordinates can be specified. If they are not, the
point defaults to the origin.
:param x: float x-coordinate
:param y: float x-coordinate
"""
self.move(x, y)
def move(self, x: float, y: float) -> None:
"""
Move the point to a new location in 2D space.
:param x: float x-coordinate
:param y: float x-coordinate
"""
self.x = x
self.y = y
def reset(self) -> None:
"""
Reset the point back to the geometric origin: 0, 0
"""
self.move(0, 0)
def calculate_distance(self, other: "Point") -> float:
"""
Calculate the Euclidean distance from this point
to a second point passed as a parameter.
:param other: Point instance
:return: float distance
"""
return math.hypot(self.x - other.x, self.y - other.y)
来说一下,为什么我觉得这段代码是专业级的:
- 类名和方法名都非常直观,简单易懂。有没有?
- 通过docstring,类和方法都加了非常简明扼要的文档。看起来就很像内置库的代码。
- 函数都使用类型提示,增加代码可读性,可以使用mypy等做类型检查。
- __init__函数使用了默认值,确保每个初始化出的实例都有有效的属性值。
- reset函数没有自己实现轮子,而是直接调用move方法。
- 类的docstring中提供了使用例子,可以用doctest等测试工具做代码的简单自动化测试。
关于Python技术储备
学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
一、Python所有方向的学习路线
Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、学习软件
工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
三、入门学习视频
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。