本文分三部分讲述 python 中常用的语法糖,为什么分三部分,因为考虑到大家可能对 python 中的一些特有的数据结构不太熟悉,所以首先介绍;文章的最后将会介绍一些经典的函数语法糖。
首先解释一下语法糖是什么意思,其实就是简化我们的代码,让那些复杂的操作交给解释器来完成,这些语法糖刚开始学的时候觉得很难记住,如果看别人写的语法糖更容易蒙圈,还会嘀咕别人装什么装,但是一旦自己掌握,啧啧啧,一发不可收拾,可谓真香。
语法糖(Syntactic sugar):
这里主要介绍常用语语法糖的数据结构,熟悉的小伙伴可以跳过。
在序列中元素类型可以不同,通过下标访问元素。
字符串类型、列表类型、元组类型都属于序列。

序列类型是双向索引,如上图所示。
序列类型常用的操作:

序列类型的函数与方法:

下面介绍元组类型:
元组类型是序列类型的一种扩展,但是元组一旦创建就不能修改,元组使用 ()或者tuple()创建。
接下来是列表类型,列表类型可谓是最常用的一种数据结构,该序列创建之后可以随意修改,使用[]或者list()创建,列表类型特有的函数和方法如下:

值得一提的是列表中使用 [::-1] 表示反转字符串。
集合是多个元素的无序组合,特点是元素不重复。创建使用 {} 或者 set() ;

集合操作符:

集合中常用的方法与函数:

字典类型相当于 java 中的 Map ,即映射关系类型的数据结构:
使用{}和dict()创建,使用冒号:表示键值关系。

先说一个实用的技巧,就是字符串类型和列表类型互相转换的几种方法:
list() 或者split()"".join(ls),如果不全是则使用map(str,ls)然后再join。//交换数字
a, b = b, a
//表示从b和c取一个较大的值赋值给a
a = [b, c][c > b]// 我们希望把正的放前面,负的放后面,并且分别按绝对值从小到大
lst = [1, -2, 10, -12, -4, -5, 9, 2]
// 这样即可
lst.sort(key=lambda x: (x < 0, abs(x)))// Lambda 表达式
f=lambda x:x+1
// 关于列表的列表推导式:
// 生成奇数序列
l=[2*x+1 for x in range(10)]for 的嵌套
[(x,y) for x in range(3) for y in range(3)]
[(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]还可以使用 if 语句:
new_list = [expression(i) for i in old_list if condition(i)]不过可读性极差,让别人来阅读你的代码是很痛苦的一件事。
三大函数,很有用:
filter,map,reduce首先是 filter 函数,filter 函数接受两个参数,第一个是过滤函数,第二个是可遍历的对象,用于选择出所有满足过滤条件的元素,返回一个可迭代对象。
// 去除小写字母
s=filter(lambda x:not str(x).islower(),"asdasfAsfBsdfC")map函数接受的参数类型与filter类似,它用于把函数作用于可遍历对象的每一个元素。类似于数学中映射的概念。
// 求y=2x+1
s=map(lambda x:2*x+1,range(6))reduce 函数对每个元素作累计操作,它接受的第一个参数必须是有两个参数的函数。
// 求和
from functools import reduce
s=reduce(lambda x,y:x+y,range(1,6))元组拆包:
t=(1,2,3)
x,y,z=t当然还有很多语法糖,欢迎留言补充。