ps:
/ 计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数 // 称为地板除,两个整数的除法仍然是整数 % 可以得到两个整数相除的余数对bytes类型的数据用带b前缀的单引号或双引号
x = b'ABC'encode()方法可以编码为指定的bytes decode()可以编码为指定的str 计算str包含多少个字符,可以用len()函数
%运算符就是用来格式化字符串
依次把list或tuple中的每个元素迭代出来
names = ['Michael', 'Bob', 'Tracy'] for name in names: print(name) >>> list(range(5)) [0, 1, 2, 3, 4]pop(key)方法删除key,对应的value也会从dict中删除
和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key
s = set([1, 1, 2, 2, 3, 3])add(key)方法可以添加元素到set中,可以重复添加,但不会有效果remove(key)方法可以删除元素必须指向不变对象
def add_end(L=None): if L is None: L = [] L.append('END') return L可变参数允许你传入0个或任意个参数,这些可变参数在函数调用时自动组装为一个tuple
def calc(*numbers): sum = 0 for n in numbers: sum = sum + n * n return sumps *nums表示把nums这个list的所有元素作为可变参数传进去
关键字参数允许你传入0个或任意个含参数名的参数,这些关键字参数在函数内部自动组装为一个dict
def person(name, age, **kw): print('name:', name, 'age:', age, 'other:', kw)只接收city和job作为关键字参数
def person(name, age, *, city, job): print(name, age, city, job)如果函数定义中已经有了一个可变参数,后面跟着的命名关键字参数就不再需要一个特殊分隔符*了
必选参数、默认参数、可变参数、命名关键字参数和关键字参数
2.1 迭代key
>>> d = {'a': 1, 'b': 2, 'c': 3} >>> for key in d: ... print(key) ... a c b2.2 迭代value
for value in d.values()2.3 同时迭代key和value
for k, v in d.items()加上if判断
>>> [x * x for x in range(1, 11) if x % 2 == 0] [4, 16, 36, 64, 100]两层循环
>>> [m + n for m in 'ABC' for n in 'XYZ'] ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']map
map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回
>>> list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9])) ['1', '2', '3', '4', '5', '6', '7', '8', '9']2.reduce
reduce把一个函数作用在一个序列[x1, x2, x3, …]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算
reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4) >>> from functools import reduce >>> def add(x, y): ... return x + y ... >>> reduce(add, [1, 3, 5, 7, 9]) 25