前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >鲜为人知的Python功能

鲜为人知的Python功能

作者头像
人工智能小咖
修改2020-06-15 10:46:23
4230
修改2020-06-15 10:46:23
举报
文章被收录于专栏:人工智能小咖人工智能小咖

Python中经常不被人所知且被低估的功能示例。

图源:Unsplash马库斯·斯皮克摄
图源:Unsplash马库斯·斯皮克摄

每当我了解到Python中的新功能,或者我注意到其他一些人没有注意到的某个功能时,我就会把它记录下来。

在过去的几周里,我了解到一些有趣的功能——例如Stack Overflow上一些我不知道的功能。

下面是其中一些功能及其简要介绍。

divmod

这是一个非常有用的函数。其作用是:对两个数执行模除%运算,然后返回商和余数。例如:

divmod(5, 2)

[Out]: (2, 1)

这只是在找到可以将2拟合为5的次数,我们不需要拆分这个数,就可以得出商为2,1为余数。

这对于计算返回进程运行所需的时间(以小时、分钟和秒为单位)特别有用。就像这样:

start = datetime.datetime.now() ... # process code goes hereend = datetime.datetime.now()# we get the total runtime in seconds runtime = (end - start).seconds # we will assume 30000# how many hours are in these secs, what are the remaining secs? hours, remainder = divmod(runtime, 3600)# now how many minutes and seconds are in our remainder? mins, secs = divmod(remainder, 60)print("{:02d}:{:02d}:{:02d}".format(hours, mins, secs))

[Out]: "08:00:08"

*args, **kwargs

有时,你可能会注意到函数定义包含这两个参数,例如 def func(x,y,* args,** kwargs)。

它们实际上都是非常简单的功能。两者都允许我们将多个值传递给一个函数,然后将其打包到一个生成器中。

关于是否将列表/生成器传递给标准参数,其结果类似:

def func(values): for x in values: print(x, end=" ")func([1, 2, 3])

[Out]: '1 2 3 '

现在,使用* args ——我们应该将每个值作为新参数传递,而不是将它们全部包含在列表中。

def func(*values): for x in values: print(x, end=" ")func(1, 2, 3)

[Out]: 1 2 3

请注意,不需要输入* args,只需输入* values。由于单个星号*,它被定义为* args,这和使用的变量名称无关。

* args只是根据传递给函数的参数创建一个生成器对象。

** kwargs创建字典。因此,可以这样使用名称、关键字参数:

def func(**values): for x in values: print(f"{x}: {values[x]}")func(x=1, y=2, z=3)[Out]: x: 1 y: 2 z: 3

同样,可以随意调用变量,在这种情况下,使用** values。 通过使用双引号将其定义为**kwargs。

列表理解

这绝对是Python最有用的功能之一,理解表达式是必不可少的。最常见的是列表理解,我敢肯定绝大多数人都看过以下内容:

vals = [1, 2, 3, 4, 5][i**2 for i in vals]

[Out]: [1, 4, 9, 16, 25]

但不限于这些方括号。可以用几乎完全相同的语法定义生成器表达式

(i**2 for i in vals)

[Out]: <generator object <genexpr> at 0x7f0281730fc0>

当然,生成器中的每个元素仅在被调用时才输出,可以使用list()来做到这一点:

list((i**2 for i in vals))

[Out]: [1, 4, 9, 16, 25]

只需对语法进行一点小的更改,甚至可以使用字典理解来构建字典:

{i: i**2 for i in vals}[Out]: {1: 1, 2: 4, 3: 9, 4: 16, 5: 25}

casefold

这是一个特别有趣的字符串方法,它的功能类似于lower。 但是,casefold试图更积极地标准化更广泛的字符。

在大多数情况下,lower和casefold的行为相同,但有时它们不相同:

"ς".casefold() # both ς and σ are the Greek letter sigma[Out]: "σ"

相比之下,使用lower:

"ς".lower() # however, lower recognizes them as different[Out]: "ς"

[Out]: False

在这里,两个sigma已经都是小写。 根据使用情况,它可能会按预期运行。

但是,如果打算比较两个等效的希腊语单词,一个使用σ,另一个使用ς。尽管相同,但只有casefold才能让我们准确地比较它们:

"ἑρμῆσ" == "ἑρμῆς"[Out]: False"ἑρμῆσ".lower() == "ἑρμῆς".lower()[Out]: False"ἑρμῆσ".casefold() == "ἑρμῆς".casefold()[Out]: True

希望你从本文中有所收获,特别是 divmod 和 casefold 都是非常有趣的功能,我最近才体验过。

如果您想分享任何独特、有趣或鲜为人知的Python功能,请告诉我,我很乐意看到它们!

感谢阅读!

本文系外文翻译,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系外文翻译前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • divmod
  • *args, **kwargs
  • 列表理解
  • casefold
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档