本文共 3611 字,大约阅读时间需要 12 分钟。
1. 以单引号'或双引号"括起来的任意文本 2. 转义字符 \ 3. r''表示''内部的字符串默认不转义
>>> print('\\\t\\')\\>>> print(r'\\\t\\')\\\t\\
4. '''...'''的格式表示多行内容
>>> print('''line1... line2... line3''')line1line2line3
True、False
None表示。None不能理解为0,因为0是有意义的,而None是一个特殊的空值。
变量名必须是大小写英文、数字和_的组合,且不能用数字开头
通常用全部大写的变量名表示常量
ps:
/ 计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数// 称为地板除,两个整数的除法仍然是整数% 可以得到两个整数相除的余数
对bytes类型的数据用带b前缀的单引号或双引号
x = b'ABC'
encode()方法可以编码为指定的bytes
decode()可以编码为指定的str 计算str包含多少个字符,可以用len()函数%运算符就是用来格式化字符串
if <条件判断1> : <执行1> elif <条件判断2> : <执行2> elif <条件判断3> : <执行3> else: <执行4>执行4> 执行3> 条件判断3> 执行2> 条件判断2> 执行1> 条件判断1>
依次把list或tuple中的每个元素迭代出来
names = ['Michael', 'Bob', 'Tracy']for name in names: print(name)
>>> list(range(5))[0, 1, 2, 3, 4]
sum = 0n = 99while n > 0: sum = sum + n n = n - 2print(sum)
键-值(key-value)存储
>>> d.get('Thomas')>>> d.get('Thomas', -1)-1
pop(key)方法删除key,对应的value也会从dict中删除
和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key
def my_abs(x): if not isinstance(x, (int, float)): raise TypeError('bad operand type') if x >= 0: return x else: return -x
def power(x, n=2): s = 1 while n > 0: n = n - 1 s = s * x return s
必须指向不变对象
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 sum
ps
*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)
如果函数定义中已经有了一个可变参数,后面跟着的命名关键字参数就不再需要一个特殊分隔符*了
必选参数、默认参数、可变参数、命名关键字参数和关键字参数
for (i=0; i
2.1 迭代key
>>> d = { 'a': 1, 'b': 2, 'c': 3}>>> for key in d:... print(key)...acb
2.2 迭代value
for value in d.values()
2.3 同时迭代key和value
for k, v in d.items()
>>> for ch in 'ABC':... print(ch)...ABC
>>> from collections import Iterable>>> isinstance('abc', Iterable) # str是否可迭代True>>> isinstance([1,2,3], Iterable) # list是否可迭代True>>> isinstance(123, Iterable) # 整数是否可迭代False
>>> for i, value in enumerate(['A', 'B', 'C']):... print(i, value)...0 A1 B2 C
>>> [x * x for x in range(1, 11)][1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
加上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
转载地址:http://stqli.baihongyu.com/