在本文中,作者介绍了 5 种方法,也许在入门阶段时,我们还不太了解它们,但在实战中这 5 个技巧非常实用。
字符串运算
字符串本质上也是一种元组,但是字符串有很多「运算」方式。最直观的是字符串的 + 和 * 运算,它们分别表示重复和连接。
> my_string = "Hi Medium..!" > print(my_string * 2) Hi Medium..!Hi Medium..! > print(my_string + " I love Python" * 2) Hi Medium..! I love Python I love Python
此外,如果希望获得反向字符串,也可以直接使用 [::-1] 进行索引:
> print(my_string[::-1]) !..muideM iH> my_list = [1,2,3,4,5] > print(my_list[::-1]) [5, 4, 3, 2, 1]
如果列表元素都是字符串,那么我们可以快速地使用 join() 方法将所有元素拼接在一起:
> word_list = ["awesome", "is", "this"] > print(' '.join(word_list[::-1]) + '!') this is awesome!
如上我们使用 .join() 方法拼接列表元素,其中 『 』 表示连接方式为空格。其实在自然语言处理中,这个方法会经常使用,例如我们将句子拆分为了字符,那么处理后的合并就需要使用 join() 了。
列表推导式
如果你还不会使用列表推导式,那么快学起来吧。正如本文作者所言,「当我第一次学到这种方式时,我的整个世界都变了。」列表推导式真的非常强大,它不仅在速度上比一般的方法快,同时直观性、可读性都非常强。如果你希望迭代列表做一些运算,那么快使用它吧。
我们先定义一个简单的函数,它会算变量的平方并加 5:
> def stupid_func(x): > return x**2 + 5
如果我们希望将该函数应用到列表中的奇数项,那么不采用列表推导式的情况下,我们一般会写成以下形式:
> my_list = [1, 2, 3, 4, 5] > new_list = [] > for x in my_list: > if x % 2 != 0: > new_list.append(stupid_func(x)) > print(new_list) [6, 14, 30]
但是现在我们有了列表推导式,那么上面代码可以等价修改为:
> my_list = [1, 2, 3, 4, 5] > print([stupid_func(x) for x in my_list if x % 2 != 0]) [6, 14, 30]
列表推导式的一般语法可以表示为 [ expression for item in list ],如果你希望加上一些布尔型条件语句,那么上面的语法可以修改为 [ expression for item in list if conditional ],它的结构其实和下面是等价的。
> for item in list: > if conditional: > expression
上面的列表推导式可以进一步简化,即不需要定义一个新函数。
> print([x ** 2 + 5 for x in my_list if x % 2 != 0]) [6, 14, 30]
Lambda 和 Map
Lambda 是一种匿名函数,它看起来可能有一点奇怪,但是一旦你理解了它,那么他就会变得非常直观与强大。
一般而言,Lambda 函数都比较小,它也不需要定义函数名。那么为什么需要匿名函数?简单而言,Lambda 最常执行一些直观的运算,它并不需要标准的函数定义,而且也不需要新的函数名再次调用。
还是拿上面的先平方再加 5 为例,前面我们是定义了一个标准的函数,def stupid_func(x),现在我们可以试试 Lambda 匿名函数:
> stupid_func = (lambda x : x ** 2 + 5) > print([stupid_func(1), stupid_func(3), stupid_func(5)]) [6, 14, 30]
那么我们为什么要用上面的表达式?很大一部分原因在于,当我们想执行一些简单运算时,可以不需要定义真实函数就能完成。例如排序列表元素,一种直观的方法可以使用 sorted() 方法:
> my_list = [2, 1, 0, -1, -2] > print(sorted(my_list)) [-2, -1, 0, 1, 2]
这只能默认从大到小或从小到大排序,但是借助 Lambda 表达式,我们可以实现更自由的排序标准。如下所示我们希望根据最小的平方数对列表进行排序,其可以使用 Lambda 函数定义键,从而告诉 sorted() 方法该怎样排序。
> print(sorted(my_list, key = lambda x : x ** 2)) [0, -1, 1, -2, 2]
Map 是一个简单的函数,它可以将某个函数应用到其它一些序列元素,例如列表。如果我们有两个列表,我们希望将这两个列表对应的元素相乘,那么使用 lambda 函数和 map 可以快速实现这一功能:
> print(list(map(lambda x, y : x * y, [1, 2, 3], [4, 5, 6]))) [4, 10, 18]
上面的代码非常优雅,如果不用它们两者,那么一般的表达需要写成这样:
> x, y = [1, 2, 3], [4, 5, 6] > z = [] > for i in range(len(x)): > z.append(x[i] * y[i]) > print(z) [4, 10, 18]
单行条件语句
如果我们使用条件语句,那么最可能写成下面这个样子:
> x = int(input()) > if x >= 10: > print("Horse") > elif 1 < x < 10: > print("Duck") > else: > print("Baguette")
但其实我们也可以把所有条件都写在 print 函数内,即上面 7 行代码可以等价写成如下一行:
print("Horse" if x >= 10 else "Duck" if 1 < x < 10 else "Baguette")
这样看起来真的非常简洁,如果你查看以前写的代码,真的有很多都可以改成这种表达式。
zip()
前面在介绍 map() 函数时,我们举了个例子将某个函数应用到平行的两个列表,而 zip() 函数可以更简单地做到这一点。
如果我们有两个列表,第一个列表包含了名,第二个列表包含了姓。使用 zip() 函数,如下我们可以将它们拼接在一起。
> first_names = ["Peter", "Christian", "Klaus"] > last_names = ["Jensen", "Smith", "Nistrup"] > print([' '.join(x) for x in zip(first_names, last_names)]) ['Peter Jensen', 'Christian Smith', 'Klaus Nistrup']
也就是说,zip 将两个等长的列表变为了一对一对的,即 (("Peter", "Jensen"), ("Christian", "Smith"), ("Klaus", "Nistrup"))。
以上就是Python之从列表推导到zip()函数的五种技巧的详细内容,更多请关注其它相关文章!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?