程序员必知的20个Python技巧

作者 | Duomly

译者 | 弯月,编辑 | 郭芮

出品 | CSDN(ID:CSDNnews)

Python是一门流行且应用广泛的通用编程语言,其应用包括数据科学、机器学习、科学计算等领域,以及后端Web开发、移动和桌面应用程序等方面。许多知名的公司都使用Python,如Google、Dropbox、Facebook、Mozilla、IBM、Quora、Amazon、Spotify、NASA、Netflix、Reddit等。

Python是免费且开源的,与它有关的大多数产品也都是。此外,它拥有庞大、专注且友善的编程者和使用者社区。

它的语法设计目标就是简单、易读且优雅。

本文将向你展示20条非常实用的Python使用技巧。

Python之禅

Python之禅(又名PEP20)是由Tim Peters编写的一小段文字,文中展示了设计和使用Python的指导原则。你可以在Python网站上找到这段文字,也可以在控制台或Jupyter notebook中通过一条语句来显示这段话。

>>> import this
The Zen of Python, by Tim Peters
Beautiful is better than ugly.
Explicit is better than implicit.
Simple is better than complex.
Complex is better than complicated.
Flat is better than nested.
Sparse is better than dense.
Readability counts.
Special cases aren't special enough to break the rules.
Although practicality beats purity.
Errors should never pass silently.
Unless explicitly silenced.
In the face of ambiguity, refuse the temptation to guess.
There should be one-- and preferably only one --obvious way to do it.
Although that way may not be obvious at first unless you're Dutch.
Now is better than never.
Although never is often better than *right* now.
If the implementation is hard to explain, it's a bad idea.
If the implementation is easy to explain, it may be a good idea.
Namespaces are one honking great idea -- let's do more of those!

链式赋值

如果需要让多个变量引用同一个对象,则可以使用链式赋值:

>>> x = y = z = 2
>>> x, y, z
(2, 2, 2)

非常有逻辑且优雅,对吧?

链式比较

多个比较语句也可以合成一个Python表达式,只需将多个比较运算符连起来即可。下面的表达式只有在所有比较都成立时返回True,否则返回False:

>>> x = 5
>>> 2 < x ≤ 8
True
>>> 6 < x ≤ 8
False

这个表达式相当于(2 < x)且 (x ≤ 8) 且 (x ≤ 8),但更为紧凑,而且只需执行一次x求值。

如下写法也是正确的:

>>> 2 < x > 4
True

甚至可以将多个比较连起来:

>>> x = 2
>>> y = 8
>>> 0 < x < 4 < y < 16
True

多重赋值

你可以使用元组解包,在一条语句中给多个变量赋值:

>>> x, y, z = 2, 4, 8
>>> x
2
>>> y
4
>>> z
8

注意第一条语句中的2, 4, 8相当于一个元组(2, 4, 8)。

更高级的多重赋值

Python的多重赋值远不止于普通赋值。赋值左右两侧的元素数量甚至可以不一样:

>>> x, *y, z = 2, 4, 8, 16
>>> x
2
>>> y
[4, 8]
>>> z
16

在这段代码中,x对应于第一个值2,因为2是首先出现的。z是最后一个,所以取最后一个值8。y以列表形式取中间的所有值,因为它带有星号(y*)。

交变量

利用多重赋值可以精确、优雅地交换任何两个变量,而且无需引入第三个变量:

>>> x, y = 2, 8
>>> x
2
>>> y
8
>>> x, y = y, x
>>> x
8
>>> y 2

合并字典

合并两个字典的方法之一就是将它们解包到一个新的字典中:

>>> x = {'u': 1}
>>> y = {'v': 2}
>>> z = {**x, **y, 'w': 4}
>>> z
{'u': 1, 'v': 2, 'w': 4}

连接字符串

如果需要连接多个字符串,每个字符串之间使用同一个字符或同一组字符来连接,则可以使用str.join()方法:

>>> x = ['u', 'v', 'w']
>>> y = '-*-'.join(x)
>>> y
'u-*-v-*-w'

高级遍历

如果需要遍历一个序列,同时还需要每个元素和相应的索引,则可以使用enumerate:

>>> for i, item in enumerate(['u', 'v', 'w']):
... print('index:', i, 'element:', item)
...
index: 0 element: u
index: 1 element: v
index: 2 element: w

每次遍历你都会获得一个元组,其中包括索引值和对应的元素。

反向遍历

如果你需要反向遍历一个序列,则可以使用reversed:

>>> for item in reversed(['u', 'v', 'w']):
... print(item)
...
w
v
u

元素结合

如果你需要将来自多个序列的元素结合起来,可以使用zip:

>>> x = [1, 2, 4]
>>> y = ('u', 'v', 'w')
>>> z = zip(x, y)
>>> z

>>> list(z)
[(1, 'u'), (2, 'v'), (4, 'w')]

你可以遍历返回的zip对象,或者将其变成一个列表或元祖。

矩阵转置

虽然在处理矩阵时人们通常会使用numpy(或类似的库),但利用zip也可以实现矩阵转置:

>>> x = [(1, 2, 4), ('u', 'v', 'w')]
>>> y = zip(*x)
>>> z = list(y)
>>> z
[(1, 'u'), (2, 'v'), (4, 'w')]

唯一值

如果元素的顺序不重要,那么从列表中去除重复值的方法是将其转换成一个集合,以获得唯一的值:

>>> x = [1, 2, 1, 4, 8]
>>> y = set(x)
>>> y
{8, 1, 2, 4}
>>> z = list(y)
>>> z
[8, 1, 2, 4]

序列排序

默认情况下序列按照第一个元素的顺序排序:

>>> x = (1, 'v')
>>> y = (4, 'u')
>>> z = (2, 'w')
>>> sorted([x, y, z])
[(1, 'v'), (2, 'w'), (4, 'u')]

但是,如果你希望按照第二个元素(或其他元素)排序,则可以使用key参数和适当的lambda函数作为第二个参数:

>>> sorted([x, y, z], key=lambda item: item[1])
[(4, 'u'), (1, 'v'), (2, 'w')]

反向排序时也使用类似的方法:

>>> sorted([x, y, z], key=lambda item: item[1], reverse=True)
[(2, 'w'), (1, 'v'), (4, 'u')]

字典排序

可以用类似方法,对字典的.items()方法返回的键值对进行排序:

>>> x = {'u': 4, 'w': 2, 'v': 1}
>>> sorted(x.items())
[('u', 4), ('v', 1), ('w', 2)]

它们按照键的顺序进行排序。如果你希望按照值排序,则应该指定相应的key参数。反向排序也类似:

>>> sorted(x.items(), key=lambda item: item[1])
[('v', 1), ('w', 2), ('u', 4)]
>>> sorted(x.items(), key=lambda item: item[1], reverse=True)
[('u', 4), ('w', 2), ('v', 1)]

格式化raw字符串

PEP498和Python 3.6引入了“有格式字符串”的概念,或者称为“f字符串”。这种字符串内部可以嵌入表达式。字符串可以同时作为raw字符串和有格式字符串使用,只需使用前缀fr:

>>> fr'u \ n v w={2 + 8}'
'u \\ n v w=10'

获取当前日期和时间

Python有一个内置的datetime模块,非常适合各种涉及到日期和时间的任务。方法之一.now()能够返回当前日期和时间:

>>> import datetime
>>> datetime.datetime.now()
datetime.datetime(2019, 5, 20, 1, 12, 31, 230217)

获取最大(或最小)元素的索引

Python没有提供直接获取最大(或最小)元素索引的函数。不过,至少有两种方法可以优雅地实现这一点:

>>> x = [2, 1, 4, 16, 8]
>>> max((item, i) for i, item in enumerate(x))[1]
3

如果有两个或多个元素都是最大值,那么该方法返回最后一个的索引:

>>> y = [2, 1, 4, 8, 8]
>>> max((item, i) for i, item in enumerate(y))[1]
4

如果想获取第一个,则可以对上面的语句稍作改动:

>>> -max((item, -i) for i, item in enumerate(y))[1]
3

另一种方法可能更优雅:

>>> x = [2, 1, 4, 16, 8]
>>> max(range(len(x)), key=lambda i: x[i])
3
>>> y = [2, 1, 4, 8, 8]
>>> max(range(len(y)), key=lambda i: x[i])
3

如果想获得最小元素的索引,则只需用min替换上面的max。

获取笛卡尔积

内置的itertools模块提供了许多非常实用的类。其中之一就是product函数,你可以通过这个函数来获得笛卡尔积:

>>> import itertools
>>> x, y, z = (2, 8), ['u', 'v', 'w'], {True, False}
>>> list(itertools.product(x, y, z))
[(2, 'u', False), (2, 'u', True), (2, 'v', False), (2, 'v', True),
(2, 'w', False), (2, 'w', True), (8, 'u', False), (8, 'u', True),
(8, 'v', False), (8, 'v', True), (8, 'w', False), (8, 'w', True)]

矩阵乘法操作符

PEP465和Python 3.5引入了专用的矩阵乘法运算符@。你可以在自己的类中实现matmul、rmatmul和imatmul来支持这个操作符。使用该操作符进行向量或矩阵乘法非常优雅:

>>> import numpy as np
>>> x, y = np.array([1, 3, 5]), np.array([2, 4, 6])
>>> z = x @ y
>>> z
44

总结

上面的20条Python技巧可以让代码变得很有趣、很优雅。Python还有许多值得探索的特性。编程快乐!

原文链接:

https://dev.to/duomly/20-useful-python-tips-and-tricks-you-should-know-3h8c

(*本文为AI科技大本营转载文章,转载请联系原作者)

本文分享自微信公众号 - AI科技大本营(rgznai100)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-11-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏测试游记

测试开发进阶(二十八)

进入 get_object_or_404可以看到一个解包,这样就拿到了查询集中 id=1的内容

6130
来自专栏中科院渣渣博肆僧一枚

tf.compat

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

5030
来自专栏华章科技

Python 3.8已正式发布,重要新功能都在这里了

导读:最新版本的Python发布了!今年夏天,Python 3.8发布beta版本,在2019年10月14日,第一个正式版本已准备就绪。现在,我们都可以开始使用...

33340
来自专栏磐创AI技术团队的专栏

PyTorch&TensorFlow跑分对决:哪个平台运行NLP模型推理更快

开源社区的支持度、上手的难易度都是重要的参考。还有人说:学术界用PyTorch,工业界用TensorFlow。

7120
来自专栏生信技能树

爬虫那么危险,干嘛不直接基因数据库下载文件呢?

问了具体后,才知道原来是ncbi上的信息,相当于在ncbi上在gene库中查找,然后爬取目标信息。如下:

17830
来自专栏Datawhale专栏

大数据处理实践!手把手实现PySpark机器学习项目-回归算法

PySpark作为工业界常用于处理大数据以及分布式计算的工具,特别是在算法建模时起到了非常大的作用。PySpark如何建模呢?这篇文章手把手带你入门PySpa...

11270
来自专栏量子位

英伟达小姐姐的Python隐藏技巧合集,推特2400赞,代码可以直接跑

常常发资源的英伟达工程师小姐姐Chip Huyen,又发射了一套Python隐藏功能合集。

8530
来自专栏量子位

微软VS Code已原生支持Jupyter笔记本,再也不用打开网页调试运行了

本月,微软给VS Code加入了一项令人感到惊喜的功能:直接在编辑器中运行调试Jupyter Notebook,而无需任何第三方插件。

30140
来自专栏盟主来了

19.9.29日报:怎样用make_css_property_names.py来生成CSSPropertyNames.cpp

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

9440
来自专栏Python工程师

Python-科学计算-pandas-01-df获取部分数据

系统:Windows 7 语言版本:Anaconda3-4.3.0.1-Windows-x86_64 编辑器:pycharm-community-2016.3....

8330

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励