小二货AI之旅第一站
python基础
1. 注释:
#此处为注释,不可换行
'''此处为注释,可换行'''
2. 运算符号
- 算术运算
+ 加 1 + 1
- 减 2 - 1
* 乘 3 * 4
/ 除 3 / 4
// 整除 3 // 4
% 取余 3 % 4
** 幂 2 ** 3
- 比较运算
> 大于 2 > 1
>= 大于等于 2 >= 4
< 小于 1 < 2
<= 小于等于 5 <= 2
== 等于 3 == 4
!= 不等于 3 != 5
- 逻辑运算
and 与 (3 > 2) and (3 < 5)
or 或 (1 > 3) or (9 < 2)
not 非 not (2 > 1)
- 位运算
~ 按位取反 ~4
& 按位与 4 & 5
` ` 按位或
^ 按位异或 4 ^ 5
<< 左移 4 << 2
>> 右移 4 >> 2
- 其他运算符
in 存在 'A' in ['A', 'B', 'C']
not in 不存在 'h' not in ['A', 'B', 'C']
is 是 "hello" is "hello"
not is 不是 "hello" is not "hello"
- 运算符优先级
** 指数(最高优先级)
~+- 按位翻转,一元加号和减号
* / % // 乘,除,取模和取整除)
+ - 加法减法
>> << 右移,左移运算符
& 位‘AND’
^| 位运算符
<=<>>= 比较运算符
<>==!= 等于运算符
=%=/=//=-=+==*= 赋值运算符
is is not 身份运算符
in not in 成员运算符
not and or 逻辑运算符
3.变量和赋值
- 变量使用前,先赋值
- 变量名可用字母,数字,下划线,开头不能为数字
- 注意变量的大小写
4.数据类型与转换
int 整型 <class 'int'> -876, 10
float 浮点型<class 'float'> 3.149, 11.11
bool 布尔型<class 'bool'> True, False
可以通过print()查看类型
a = 1031
print(a, type(a))
结果:
1031 <class 'int'>
type() 不会认为子类是一种父类类型,不考虑继承关系
isinstance() 会认为子类是一种父类类型,考虑继承关系
5. print()函数
- 将对象以字符串表示的方式格式化输出到流文件对象file里。其中所有非关键字参数都按str()方式进行转换为字符串输出;
- 关键字参数sep是实现分隔符,比如多个参数输出时想要输出中间的分隔字符;
- 关键字参数end是输出结束时的字符,默认是换行符\n;
- 关键字参数file是定义流输出的文件,可以是标准的系统输出sys.stdout,也可以重定义为别的文件;
- 关键字参数flush是立即把内容输出到流文件,不作缓存。
- 没有参数时,每次都会换行输出。
6. 位运算
- 原码:二进制表示
- 反码:正数反码为原码,负数符号不变,其余取反
- 补码:正数——原码,负数——反码+1
- 按位运算:
按位非操作 ~
~ 1 = 0
~ 0 = 1
~ 把num的补码中的 0 和 1 全部取反(0 变为 1,1 变为 0)有符号整数的符号位在 ~ 运算中同样会取反。
00 00 01 01 -> 5
~
---
11 11 10 10 -> -6
11 11 10 11 -> -5
~
---
00 00 01 00 -> 4
按位与操作 &
1 & 1 = 1
1 & 0 = 0
0 & 1 = 0
0 & 0 = 0
只有两个对应位都为 1 时才为 1
00 00 01 01 -> 5
&
00 00 01 10 -> 6
---
00 00 01 00 -> 4
按位或操作 |
1 | 1 = 1
1 | 0 = 1
0 | 1 = 1
0 | 0 = 0
只要两个对应位中有一个 1 时就为 1
00 00 01 01 -> 5
|
00 00 01 10 -> 6
---
00 00 01 11 -> 7
按位异或操作 ^
1 ^ 1 = 0
1 ^ 0 = 1
0 ^ 1 = 1
0 ^ 0 = 0
只有两个对应位不同时才为 1
00 00 01 01 -> 5
^
00 00 01 10 -> 6
---
00 00 00 11 -> 3
异或操作的性质:满足交换律和结合律
A: 00 00 11 00
B: 00 00 01 11
A^B: 00 00 10 11
B^A: 00 00 10 11
A^A: 00 00 00 00
A^0: 00 00 11 00
A^B^A: = A^A^B = B = 00 00 01 11
按位左移操作 <<
num << i 将num的二进制表示向左移动i位所得的值。
00 00 10 11 -> 11
11 << 3
---
01 01 10 00 -> 88
按位右移操作 >>
num >> i 将num的二进制表示向右移动i位所得的值。
00 00 10 11 -> 11
11 >> 2
---
00 00 00 10 -> 2
7.利用位运算计算
通过 <<,>> 快速计算2的倍数问题。
n << 1 -> 计算 n*2
n >> 1 -> 计算 n/2,负奇数的运算不可用
n << m -> 计算 n*(2^m),即乘以 2 的 m 次方
n >> m -> 计算 n/(2^m),即除以 2 的 m 次方
1 << n -> 2^n
通过 ^ 快速交换两个整数。 通过 ^ 快速交换两个整数。
a ^= b
b ^= a
a ^= b
通过 a & (-a) 快速获取a的最后为 1 位置的整数。
00 00 01 01 -> 5
&
11 11 10 11 -> -5
---
00 00 00 01 -> 1
00 00 11 10 -> 14
&
11 11 00 10 -> -14
---
00 00 00 10 -> 2
8. 利用位运算实现整数集合
一个数的二进制表示可以看作是一个集合(0 表示不在集合中,1 表示在集合中)。
比如集合 {1, 3, 4, 8},可以表示成 01 00 01 10 10 而对应的位运算也就可以看作是对集合进行的操作。
元素与集合的操作:
a | (1<<i) -> 把 i 插入到集合中
a & ~(1<<i) -> 把 i 从集合中删除
a & (1<<i) -> 判断 i 是否属于该集合(零不属于,非零属于)
集合之间的操作:
a 补 -> ~a
a 交 b -> a & b
a 并 b -> a | b
a 差 b -> a & (~b)
注意:整数在内存中以补码的形式存在,输出也是按照补码输出。
- Python中bin一个负数(十进制表示),输出的是它的原码的二进制表示加上个负号
- Python中的整型是补码形式存储的。
- Python中整型是不限制长度的不会超范围溢出。
负数(十进制表示)的补码:将其和十六进制数0xffffffff进行按位与操作,再交给bin()进行输出。
条件语句
if
语句
构成:
if expression:
expr_true_suite
注意:先判断后执行
- if 语句的 expr_true_suite 代码块只有当条件表达式 expression 结果为真时才执行,否则将继续执行紧跟在该代码块后面的语句。
- 单个 if 语句中的 expression 条件表达式可以通过布尔操作符 and,or和not 实现多重条件判断
if - else
语句
构成:
if expression:
expr_true_suite
else:
expr_false_suite
- 如果 if 语句的条件表达式结果布尔值为假,那么程序将执行 else 语句后的代码.
- if语句支持嵌套,即在一个if语句中嵌入另一个if语句,从而构成不同层次的选择结构。
if- elif - else
语句
构成:
if expression1:
expr1_true_suite
elif expression2:
expr2_true_suite
.
.
elif expressionN:
exprN_true_suite
else:
expr_false_suite
elif 语句即为 else if,用来检查多个表达式是否为真,并在为真时执行特定代码块中的代码
assert
关键词
- assert这个关键词我们称之为“断言”,当这个关键词后边的条件为 False 时,程序自动崩溃并抛出AssertionError的异常
- 在进行单元测试时,可以用来在程序中置入检查点,只有条件为 True 才能让程序正常工作。
循环语句
while
循环
构成:
while 布尔表达式:
代码块
- while循环的代码块会一直循环执行,直到布尔表达式的值为布尔假
- 如果布尔表达式不带有<、>、==、!=、in、not in等运算符,仅仅给出数值之类的条件,也是可以的。
- 当while后写入一个非零整数时,视为真值,执行循环体;写入0时,视为假值,不执行循环体。
- 写入str、list或任何序列,长度非零则视为真值,执行循环体;否则视为假值,不执行循环体
- 布尔表达式返回0,循环终止
while - else
循环
构成:
while 布尔表达式:
代码块
else:
代码块
执行:while — else(无打断语句eg:break)
for
循环
构成:
for 迭代变量 in 可迭代对象:
代码块
**注释:迭代变量-- i 可迭代对象-- ‘ILoveLSGO’
for i in 'ILoveLSGO':
print(i, end=' ') # 不换行输出
结果: I L o v e L S G O
- for循环是迭代循环,在Python中相当于一个通用的序列迭代器,可以遍历任何有序序列,如str、list、tuple等,也可以遍历任何可迭代对象,如dict
- 每次循环,迭代变量被设置为可迭代对象的当前元素,提供给代码块使用
for- else
循环
构成:
for 迭代变量 in 可迭代对象:
代码块
else:
代码块
当for循环正常执行完的情况下,执行else输出,如果for循环中执行了跳出循环的语句,比如 break,将不执行else代码块的内容,与while - else语句一样
range()
函数
构成:
range([start,] stop[, step=1])
- 这个BIF(Built-in functions)有三个参数,其中用中括号括起来的两个表示这两个参数是可选的。
- step=1 步长,依据需要设置,默认为1。
- range 这个BIF的作用是生成一个从start参数的值开始到stop参数的值结束的数字序列,该序列包含start的值但不包含stop的值。
enumerate()
函数
构成:
enumerate(sequence, [start=0])
- sequence:一个序列、迭代器或其他支持迭代对象。
- start:下标起始位置。
- 返回 enumerate(枚举) 对象
- enumerate()与 for 循环的结合使用。
for i, a in enumerate(A)
do something with a
- 用
enumerate(A)
不仅返回了 A 中的元素,还顺便给该元素一个索引值 (默认从 0 开始)。此外,用enumerate(A, j)
还可以确定索引起始值为 j。
常用关键语句
- break语句可以跳出当前所在层的循环。
- continue终止本轮循环并开始下一轮循环。
- pass 语句,占位,保证结构完整,保证代码正常运行。
推导式
构成:
- 列表推导式
[ expr for value in collection [if condition] ]
- 元组推导式
( expr for value in collection [if condition] )
- 字典推导式
{ key_expr: value_expr for value in collection [if condition] }
- 集合推导式
{ expr for value in collection [if condition] }
异常处理
Python 标准异常总结
当出现异常时,可以直接网络查询相应的错误类型
- BaseException:所有异常的 基类
Exception:常规异常的 基类
StandardError:所有的内建标准异常的基类
ArithmeticError:所有数值计算异常的基类
FloatingPointError:浮点计算异常
OverflowError:数值运算超出最大限制
ZeroDivisionError:除数为零
AssertionError:断言语句(assert)失败
AttributeError:尝试访问未知的对象属性
EOFError:没有内建输入,到达EOF标记
EnvironmentError:操作系统异常的基类
IOError:输入/输出操作失败
OSError:操作系统产生的异常(例如打开一个不存在的文件)
WindowsError:系统调用失败
ImportError:导入模块失败的时候
KeyboardInterrupt:用户中断执行
LookupError:无效数据查询的基类
IndexError:索引超出序列的范围
KeyError:字典中查找一个不存在的关键字
MemoryError:内存溢出(可通过删除对象释放内存)
NameError:尝试访问一个不存在的变量
UnboundLocalError:访问未初始化的本地变量
ReferenceError:弱引用试图访问已经垃圾回收了的对象
RuntimeError:一般的运行时异常
NotImplementedError:尚未实现的方法
SyntaxError:语法错误导致的异常
IndentationError:缩进错误导致的异常
TabError:Tab和空格混用
SystemError:一般的解释器系统异常
TypeError:不同类型间的无效操作
ValueError:传入无效的参数
UnicodeError:Unicode相关的异常
UnicodeDecodeError:Unicode解码时的异常
UnicodeEncodeError:Unicode编码错误导致的异常
UnicodeTranslateError:Unicode转换错误导致的异常
Python标准警告总结
- Warning:警告的基类
DeprecationWarning:关于被弃用的特征的警告
FutureWarning:关于构造将来语义会有改变的警告
UserWarning:用户代码生成的警告
PendingDeprecationWarning:关于特性将会被废弃的警告
RuntimeWarning:可疑的运行时行为(runtime behavior)的警告
SyntaxWarning:可疑语法的警告
ImportWarning:用于在导入模块过程中触发的警告
UnicodeWarning:与Unicode相关的警告
BytesWarning:与字节或字节码相关的警告
ResourceWarning:与资源使用相关的警告
try - except
语句
构成:
try:
检测范围
except Exception[as reason]:
出现异常后的处理代码
执行:
try - 无异常 - 结束
try - 异常 - 异常类型 - except相符 - 执行相关语句 - 执行try- except后的代码
try - 异常 - 与except无匹配 - try
一个try语句可能包含多个except
子句,分别来处理不同的特定的异常。最多只有一个分支会被执行
except
模块的代码需要规范排序
try - except - finally
语句
try: 检测范围 except Exception[as reason]: 出现异常后的处理代码 finally: 无论如何都会被执行的代码,无论有无异常。
try - except - else
语句
构成:
try:
检测范围
except:
出现异常后的处理代码
else:
如果没有异常执行这块代码
try子句执行时没有发生异常,Python将执行else语句后的语句; else语句的存在必须以except语句的存在为前提,在没有except语句的try语句中使用else语句,会引发语法错误
raise语句
Python 使用raise语句抛出一个指定的异常。
try:
raise NameError('HiThere')
except NameError:
print('An exception flew by!')
结果:An exception flew by!