这个词翻译过来就是 这很python,其产生的目的就是写出更简洁的,没有冗余的python代码。
1.元素交换
a, b = b, a
看到网上有人解释的很好,首先,建立元组的重点不在于括号‘()’,而是在于逗号‘,’,例如x=(1),你打印会发现x并不是一个元组,而 x=1,,这样打印x就是一个元组。
所以,a,b = b,a,这个等式的右边就是一个(b,a)元组
然后加入一个很重要的概念叫元组解包,就是把一个元组解开直接赋予几个变量,例如x y z = (a,b,c),这样会得到x=a,y=b,z=c
注意的是如果变量个数和元素个数不相等时会报错
所以最终我们可以得到一种看似神奇简便的交换变量值得写法a,b=b,a
2.迭代元素的同时获取索引
list = [1, 4, 9]
for i, val in enumerate(list):
print(i, '-->', val)
3.字符串的拼接
names = ['Tom', 'Jack', 'Sam']
','.join(names)
+操作都会产生新字符串,造成内存浪费,而join,整个过程中只会产生一个字符串对象
4.列表操作
from collections import deque names = deque(['c', 'd', 'e'])
names.popleft()
names.appendleft('b')
names.append('f')
deque模块是python标准库collections中的一项,是一个链表结构,它提供了两端都可以操作的序列,这意味着,在序列的前后你都可以执行添加或删除操作。所以,避免使用list。
5.python解析赋值
student = ['Tom', 18, 'male']
name, age, gender = student
print(name, age, gender)
# Tom 18 male num_list = [100, 19, 20, 98]
first, *left_num_list, last = num_list
print(first, left_num_list, last)
# 100 [19, 20] 98
student = {
'name': 'Tom',
'age': 18
} # python3
for k, v in student.items():
print('k', '-->', v)
6.列表生成式
# 生成1-100的奇数
odd = [i for i in range(1, 100) if i % 2 == 1] # 集合a,b分别去一个数,找出和大于100的所有组合
result = [(x, y) for x in a_set for y in b_set if x + y > 100]
当前用户home目录下所有的文件列表:[ item for item in os.listdir(os.path.expanduser('~')) if os.path.isfile(item) ]
当前用户home目录下所有的目录列表:[ item for item in os.listdir(os.path.expanduser('~')) if os.path.isdir(item) ]
当前用户home目录下所有目录的目录名到绝对路径之间的字典:{ item: os.path.realpath(item) for item in os.listdir(os.path.expanduser('~')) if os.path.isdir(item) }
7.python判断数字的区间
0 < a < 10