Python学习¶
Python3基本语法¶
编码¶
默认情况下,Python3源码文件以UTF-8编码,所有字符串都是unicode字符串。当然,也可以为源码文件制定不同的编码:
标识符¶
- 标识符必须以字母或者下划线开头
- 标识符(变量)在使用前必须先定义
- 标识符的其他部分由字母、数字和下划线组成
- 标识符对大小写敏感
- 标识符对长度无硬性限制
- 不能使用保留关键字,如if\for\class等
让人惊讶的是,python可能是第一个主流编程语言支持中文变量名的(至少据我所知是这样的)
保留字¶
>>> import keyword
>>> keyword.kwlist
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
注释¶
Python中的单行注释以#开头,多行注释可以用多个#或者使用'''或"""将注释段落包围起来,下面是例子
注意,Python3不支持嵌套注释,例如下面你的示例是不合法的,但是单行注释是可以嵌套在多行注释里面的。
行与缩进¶
python最具特色就是使用缩进来表示代码块,不需要使用大括号{}
缩进的空格数是可以改变的,但是同一个代码块的语句必须由相同的空格数。下面是实例:
下面的代码最后一行语句缩进数的空格数不一致,会导致错误:
另外,python通常是一行写完一句语句,如果语句很长,可以使用反斜杠\来实现多行语句,例如:
而在[],{},()等中的多行语句,不需要使用反斜杠\,例如
空行
函数之间或类的方法之间用空行分隔,表示一段新的代码的开始。类和函数入口之间也用一行空行分隔,以突出函数入口的开始。
空行与代码缩进不同,空行并不是 Python 语法的一部分。书写时不插入空行,Python 解释器运行也不会出错。但是空行的作用在于分隔两段不同功能或含义的代码,便于日后代码的维护或重构。
记住:空行也是程序代码的一部分。
同一行显示多条语句
python支持在同一行中使用多条语句,语句之间使用分号分隔。
数字类型¶
python中有四种数字类型:整数、布尔型、浮点数和复数
| 数字类型 | 说明 | 例子 |
|---|---|---|
| int(整数) | 只有一种整数类型int,表示为长整数型,没有python2中的Long类型 | 1 2 3 |
| bool(布尔) | 只有两种类型 | True False |
| float(浮点数) | 小数,可以使用科学计数法表示 | 1.23 3e-2(\(3\times 10^{-2} 0.03\)) |
| complex(复数) | 由实部和虚部组成,形式为\(a+bj\) | 1.1+3.2j |
字符串(String)¶
- python中单引号和双引号的使用完全相同
- 使用三引号可以指定一个多行字符串
- 转义符为
\,如果在字符前使用r可以让字符串不进行转义,如r"this is a line with \n" 则 \n 会显示,并不是换行。 - 按字面意义级联的字符串,如 "this " "is " "string" 会被自动转换为 this is string。
- 字符串可以用
+运算符连接在一起,用*运算符表示重复。 - Python中的字符串由两种索引方式,从左往右以
0开始,从右往左以-1开始 - Python中的字符串不能改变
- Python没有单独的字符类型,一个字符就是长度为1的字符串
- 字符串切片
str[start:end],其中start(包含)是切片开始的所以,end(不包含)是切片结束的索引 - 字符串的切片可以加上步长参数step,语法格式如下:
srt[start:end:step]
Example
#!/usr/bin/python3
str='123456789'
print(str) # 输出字符串
print(str[0:-1]) # 输出第一个到倒数第二个的所有字符
print(str[0]) # 输出字符串第一个字符
print(str[2:5]) # 输出从第三个开始到第六个的字符(不包含)
print(str[2:]) # 输出从第三个开始后的所有字符
print(str[1:5:2]) # 输出从第二个开始到第五个且每隔一个的字符(步长为2)
print(str * 2) # 输出字符串两次
print(str + '你好') # 连接字符串
print('------------------------------')
print('hello\nrunoob') # 使用反斜杠(\)+n转义特殊字符
print(r'hello\nrunoob') # 在字符串前面添加一个 r,表示原始字符串,不会发生转义

等待用户输入¶
执行下面你的程序在按回车键后会等待用户输入
以上代码中 ,\n\n 在结果输出前会输出两个新的空行。一旦用户按下 enter 键时,程序将退出。
多个语句构成代码组¶
缩进相同的一组语句构成一个代码块,成为代码组
像if,while,def和class这样的符合语句,首行以关键字开始,以冒号结束,改行之后的一行或者多行代码构成代码组。
将首行及后面的代码组称为一个子句,如下
print输出¶
print输出默认是换行的,如果不需要实现换行需要再变量末尾加上end=""
Example

import与from...import¶
在 python 用 import 或者 from...import 来导入相应的模块。
将整个模块(somemodule)导入,格式为: import somemodule
从某个模块中导入某个函数,格式为: from somemodule import somefunction
从某个模块中导入多个函数,格式为: from somemodule import firstfunc, secondfunc, thirdfunc
将某个模块中的全部函数导入,格式为: **from somemodule import **
Example
import sys
print('================Python import mode==========================')
print ('命令行参数为:')
for i in sys.argv:
print (i)
print ('\n python 路径为',sys.path)

命令行参数¶
很多程序可以执行一些操作来查看一些基本信息,Python可以使用-h参数查看各参数帮助信息:
$ python -h
usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-c cmd : program passed in as string (terminates option list)
-d : debug output from parser (also PYTHONDEBUG=x)
-E : ignore environment variables (such as PYTHONPATH)
-h : print this help message and exit
[ etc. ]
Python3基本数据类型¶
Python 中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。
在 Python 中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型。
等号(=)用来给变量赋值。
等号(=)运算符左边是一个变量名,等号(=)运算符右边是存储在变量中的值。
多个变量赋值¶
python允许同时为多个变量赋值。例如
或者为多个对象指定多个变量
可以通过type()函数查看变量的类型
Example

标准数据类型¶
Python3中常见的数据类型为
- Number(数字)
- String(字符串)
- bool(布尔类型)
- List(列表)
- Tuple(元组)
- Set(集合)
- Dictionary(字典)
Python3 的六个标准数据类型中:
- 不可变数据(3 个):Number(数字)、String(字符串)、Tuple(元组);
- 可变数据(3 个):List(列表)、Dictionary(字典)、Set(集合)。
此外还有一些高级的数据类型,如: 字节数组类型(bytes)。
Number数字¶
Python3 支持 int、float、bool、complex(复数)
除了使用type()函数以外,还可以使用isinstance([变量],[类型]),该函数会返回输入的变量是否为输入的类型。两者之间的差别在于isinstance()会认为子类时一种父类类型。

上面的代码是先声明类A,再声明一个子类B,即B继承自A,也就是说,B是A的一种类型。
Example
在Python3中,bool是int的子类,True和False可以和数字相加如果使用==,则会返回True,可以通过is来判断是否是bool类型。例如
>>> issubclass(bool, int)
True
>>> True==1
True
>>> False==0
True
>>> True+1
2
>>> False+1
1
>>> 1 is True
<python-input-12>:1: SyntaxWarning: "is" with 'int' literal. Did you mean "=="?
1 is True
False
>>> 0 is False
<python-input-13>:1: SyntaxWarning: "is" with 'int' literal. Did you mean "=="?
0 is False
False
什么会出现 SyntaxWarning?
Python 检测到你在用 is 比较一个字面量整数(如 1)和 True,这通常是代码错误(因为 is 比较的是身份,而不是值)。Python 建议你使用 == 来比较值是否相等,除非你确实想检查是否是同一个对象。在 Python2 中是没有布尔型的,它用数字 0 表示 False,用 1 表示 True。
数值运算¶
>>> 5 + 4 # 加法
9
>>> 4.3 - 2 # 减法
2.3
>>> 3 * 7 # 乘法
21
>>> 2 / 4 # 除法,得到一个浮点数
0.5
>>> 2 // 4 # 除法,得到一个整数,类似于\
0
>>> 17 % 3 # 取余
2
>>> 2 ** 5 # 乘方
32
- 一个变量可以通过赋值指向不同类型的对象。
- 在混合计算的时候,Python会将整型转换成浮点数。
- Python的复数可以由实部和虚部构成,
a+bj或者complex(a,b)
Note
python是一种动态类型语言,类型是绑定在对象上,而非变量上。即对象拥有类型,如数字10永远是int类型,而变量没有类型,他只储存一个引用地址,指向它当前关联的对象。当python在程序运行的时候会检查对象的类型。这一特征的优点在于代码更加简介灵活,益于开发,代价在于错误的类型对象不会再编译器刚开始运行的时候检查出来,只有程序运行到存在错误的一行会抛出typeError。当一个运行了很久的代码在中途抛出typeError就老实了(笑)
数学函数¶
| 函数 | 返回值 ( 描述 ) |
|---|---|
| abs(x) | 返回数字的绝对值,如abs(-10) 返回 10 |
| ceil(x) | 返回数字的向上取整,如math.ceil(4.1) 返回 5 |
| cmp(x, y) | 如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1。 Python 3 已废弃,使用 (x>y)-(x<y) 替换。 |
| exp(x) | 返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045 |
| fabs(x) | 以浮点数形式返回数字的绝对值,如math.fabs(-10) 返回10.0 |
| floor(x) | 返回数字的向下取整,如math.floor(4.9)返回 4 |
| log(x) | 如math.log(math.e)返回1.0,math.log(100,10)返回2.0 |
| log10(x) | 返回以10为基数的x的对数,如math.log10(100)返回 2.0 |
| max(x1, x2,...) | 返回给定参数的最大值,参数可以为序列。 |
| min(x1, x2,...) | 返回给定参数的最小值,参数可以为序列。 |
| modf(x) | 返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。 |
| pow(x, y) | x**y 运算后的值。 |
| [round(x ,n]) | 返回浮点数 x 的四舍五入值,如给出 n 值,则代表舍入到小数点后的位数。其实准确的说是保留值将保留到离上一位更近的一端。 |
| sqrt(x) | 返回数字x的平方根。 |
随机数函数¶
随机数可以用于数学,游戏,安全等领域中,还经常被嵌入到算法中,用以提高算法效率,并提高程序的安全性。
Python包含以下常用随机数函数:
| 函数 | 描述 |
|---|---|
| choice(seq) | 从序列的元素中随机挑选一个元素,比如random.choice(range(10)),从0到9中随机挑选一个整数。 |
| [randrange (start,] stop [,step]) | 从指定范围内,按指定基数递增的集合中获取一个随机数,基数默认值为 1 |
| random() | 随机生成下一个实数,它在[0,1)范围内。 |
| seed(x) | 改变随机数生成器的种子seed。如果你不了解其原理,你不必特别去设定seed,Python会帮你选择seed。 |
| shuffle(lst) | 将序列的所有元素随机排序 |
| uniform(x, y) | 随机生成下一个实数,它在[x,y]范围内。 |
三角函数¶
| 函数 | 描述 |
|---|---|
| acos(x) | 返回x的反余弦弧度值。 |
| asin(x) | 返回x的反正弦弧度值。 |
| atan(x) | 返回x的反正切弧度值。 |
| atan2(y, x) | 返回给定的 X 及 Y 坐标值的反正切值。 |
| cos(x) | 返回x的弧度的余弦值。 |
| hypot(x, y) | 返回欧几里德范数 sqrt(xx + yy)。 |
| sin(x) | 返回的x弧度的正弦值。 |
| tan(x) | 返回x弧度的正切值。 |
| degrees(x) | 将弧度转换为角度,如degrees(math.pi/2) , 返回90.0 |
| radians(x) | 将角度转换为弧度 |
数学常量¶
| 常量 | 描述 |
|---|---|
| pi | 数学常量 pi(圆周率,一般以π来表示) |
| e | 数学常量 e,e即自然常数(自然常数)。 |
其他说明¶
- Python数字数据类型用于存储数值,不允许改变,如果要改变数字数据类型的值,将重新分配内存空间。
可以使用del语句删除一些数字对象的引用
- 可以使用十六进制或者八进制来表示整数
-
数字类型转换
-
int(x) 将x转换为一个整数。
- float(x) 将x转换到一个浮点数。
- complex(x) 将x转换到一个复数,实数部分为 x,虚数部分为 0。
- complex(x, y) 将 x 和 y 转换到一个复数,实数部分为 x,虚数部分为 y。x 和 y 是数字表达式。
String(字符串)¶
基本语法¶
Python中的字符串用双引号或者单引号括起来,用反斜杠表示转义特殊字符。
字符串的截取的语法格式如下:
索引值以0开始,-1为末尾的开始位置
图片来源于:https://www.runoob.com/python3/python3-data-type.html
加号+表示字符串的链接,星号*n表示当前字符串复制n遍

Python 使用反斜杠 \转义特殊字符,如果你不想让反斜杠发生转义,可以在字符串前面添加一个 r,表示原始字符串:
另外,反斜杠()可以作为续行符,表示下一行是上一行的延续。也可以使用 """...""" 或者 '''...''' 跨越多行。
Note
与 C 字符串不同的是,Python 字符串不能被改变。向一个索引位置赋值,比如 word[0] = 'm' 会导致错误。
转义字符¶
在需要在字符中使用特殊字符时,python 用反斜杠 \ 转义字符。如下表:
| 转义字符 | 描述 | 实例 |
|---|---|---|
| (在行尾时) | 续行符 | >>> print("line1 \... line2 \... line3")line1 line2 line3>>> |
| \ | 反斜杠符号 | >>> print("\\")\ |
| \' | 单引号 | >>> print('\'')' |
| \" | 双引号 | >>> print("\"")" |
| \a | 响铃 | >>> print("\a")执行后电脑有响声。 |
| \b | 退格(Backspace) | >>> print("Hello \b World!")Hello World! |
| \000 | 空 | >>> print("\000")>>> |
| \n | 换行 | >>> print("\n")>>> |
| \v | 纵向制表符 | >>> print("Hello \v World!")HelloWorld!>>> |
| \t | 横向制表符 | >>> print("Hello \t World!")Hello World!>>> |
| \r | 回车,将 \r 后面的内容移到字符串开头,并逐一替换开头部分的字符,直至将 \r 后面的内容完全替换完成。 | >>> print("Hello\rWorld!")World!>>> print('google runoob taobao\r123456')123456 runoob taobao |
| \f | 换页 | >>> print("Hello \f World!")HelloWorld!>>> |
| \yyy | 八进制数,y 代表 0~7 的字符,例如:\012 代表换行。 | >>> print("\110\145\154\154\157\40\127\157\162\154\144\41")Hello World! |
| \xyy | 十六进制数,以 \x 开头,y 代表的字符,例如:\x0a 代表换行 | >>> print("\x48\x65\x6c\x6c\x6f\x20\x57\x6f\x72\x6c\x64\x21")Hello World! |
| \other | 其它的字符以普通格式输出 |
Example
使用\r实现百分比进度条:
bool(布尔类型)¶
布尔类型即 True 或 False。
在 Python 中,True 和 False 都是关键字,表示布尔值。
布尔类型可以用来控制程序的流程,比如判断某个条件是否成立,或者在某个条件满足时执行某段代码。
布尔类型特点:
- 布尔类型只有两个值:True 和 False。
- bool 是 int 的子类,因此布尔值可以被看作整数来使用,其中 True 等价于 1。
- 布尔类型可以和其他数据类型进行比较,比如数字、字符串等。在比较时,Python 会将 True 视为 1,False 视为 0。
- 布尔类型可以和逻辑运算符一起使用,包括 and、or 和 not。这些运算符可以用来组合多个布尔表达式,生成一个新的布尔值。
- 布尔类型也可以被转换成其他数据类型,比如整数、浮点数和字符串。在转换时,True 会被转换成 1,False 会被转换成 0。
- 可以使用
bool()函数将其他类型的值转换为布尔值。以下值在转换为布尔值时为False:None、False、零 (0、0.0、0j)、空序列(如''、()、[])和空映射(如{})。其他所有值转换为布尔值时均为True。
Note
在 Python 中,所有非零的数字和非空的字符串、列表、元组等数据类型都被视为 True,只有 0、空字符串、空列表、空元组等被视为 False。因此,在进行布尔类型转换时,需要注意数据类型的真假性。
List(列表)¶
列表可以完成大多数集合类的数据结构实现。列表中元素的类型可以不相同,它支持数字,字符串甚至可以包含列表(所谓嵌套)。
列表是写在方括号 [] 之间、用逗号分隔开的元素列表。
和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。
列表截取的语法格式如下:
列表的索引与字符串的索引类似,见下图

加号+是列表连接运算符,星号*是重复操作,这里与字符串类似。
Example
list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ] # 定义一个列表 tinylist = [123, 'runoob']
print (list) # 打印整个列表 print (list[0]) # 打印列表的第一个元素 print (list[1:3]) # 打印列表第二到第四个元素(不包含第四个元素) print (list[2:]) # 打印列表从第三个元素开始到末尾 print (tinylist * 2) # 打印tinylist列表两次 print (list + tinylist) # 打印两个列表拼接在一起的结果
与字符串不一样的是,列表中的元素是可以改变的。
List还内置了很多方法,例如append(),pop()等等,这在后面还会提到
Note
1.列表写在方括号之间,元素用逗号隔开
2.和字符串一样,列表可以被索引和切片
3.列表可以使用+操作符进行连接
4.列表中的元素是可以改变的
Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:

如果第三个参数为负数表示逆向读取,以下实例用于翻转字符串
Example
def reverseWords(input):
# 通过空格将字符串分隔符,把各个单词分隔为列表
inputWords = input.split(" ")
# 翻转字符串
# 假设列表 list = [1,2,3,4],
# list[0]=1, list[1]=2 ,而 -1 表示最后一个元素 list[-1]=4 ( 与 list[3]=4 一样)
# inputWords[-1::-1] 有三个参数
# 第一个参数 -1 表示最后一个元素
# 第二个参数为空,表示移动到列表末尾
# 第三个参数为步长,-1 表示逆向
inputWords=inputWords[-1::-1]
# 重新组合字符串
output = ' '.join(inputWords)
return output
if __name__ == "__main__":
input = 'I like runoob'
rw = reverseWords(input)
print(rw)
output
Tuple(元组)¶
元组(tuple)与列表类似,不同之处在于元组的元素不能修改。元组写在小括号 () 里,元素之间用逗号隔开。
-
元组中的元素类型也可以不相同
-
元组与字符串类似,可以被索引且下标索引从0开始,-1 为从末尾开始的位置。也可以进行截取
- 虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。
- 构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则,如果只有一个元素的元组,需要再元素后添加逗号,用于区分元组和普通的值。
Set(集合)¶
Python 中的集合(Set)是一种无序、可变的数据类型,用于存储唯一的元素。
集合中的元素不会重复,并且可以进行交集、并集、差集等常见的集合操作。
在 Python 中,集合使用大括号 {} 表示,元素之间用逗号 , 分隔。
另外,也可以使用 set() 函数创建集合。
注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
Example
#!/usr/bin/python3
sites = {'Google', 'Taobao', 'Runoob', 'Facebook', 'Zhihu', 'Baidu'}
print(sites) # 输出集合,重复的元素被自动去掉
# 成员测试
if 'Runoob' in sites :
print('Runoob 在集合中')
else :
print('Runoob 不在集合中')
```python
# set可以进行集合运算
a = set('abracadabra')
b = set('alacazam')
print(a)
print(a - b) # a 和 b 的差集
print(a | b) # a 和 b 的并集
print(a & b) # a 和 b 的交集
print(a ^ b) # a 和 b 中不同时存在的元素
output
{'Baidu', 'Runoob', 'Facebook', 'Google', 'Zhihu', 'Taobao'}
Runoob 在集合中
{'a', 'r', 'd', 'b', 'c'}
{'r', 'b', 'd'}
{'a', 'r', 'm', 'c', 'd', 'b', 'z', 'l'}
{'a', 'c'}
{'r', 'z', 'm', 'l', 'b', 'd'}
Dictionary(字典)¶
列表式有序的对象集合,字典是无序的对象集合。两者之间的区别在于:字典中的元素是通过键来存取的,而不是通过偏移存取(有点像函数里的一一对应关系)。
字典是一种映射类型,用{}标识,是一个无序的键(Key):值(Value)的集合。键(Key)必须是不可变类型,同一个字典中,键必须是唯一的。
Example

构造函数dict()可以直接从键值对序列中构建字典如下:
>>> dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
{'Runoob': 1, 'Google': 2, 'Taobao': 3}
>>> {x: x**2 for x in (2, 4, 6)}
{2: 4, 4: 16, 6: 36}
>>> dict(Runoob=1, Google=2, Taobao=3)
{'Runoob': 1, 'Google': 2, 'Taobao': 3}
注意:
- 字典是一种映射类型,它的元素是键值对
- 字典的关键字必须为不可变类型,且不能重复
- 创建空字典使用
{}
bytes类型¶
在Python3中,bytes类型表示的是不可变的二进制序列。与字符串类型不同的是,该类型中的元素是整数值(0-255之间),而不是Unicode字符。通常用于处理二进制数据。
可以用b前缀标识bytes对象。
此外,也可以使用bytes()函数将其他类型的对象转换为bytes类型。该函数的第一个参数是要转换的对象,第二个参数是编码方式,如果省略第二个参数,则默认使用UTF-8编码。
与字符串类型类似,bytes 类型也支持许多操作和方法,如切片、拼接、查找、替换等等。同时,由于 bytes 类型是不可变的,因此在进行修改操作时需要创建一个新的 bytes 对象。
需要注意的是,bytes 类型中的元素是整数值,因此在进行比较操作时需要使用相应的整数值。
Python3的数据类型转换¶
Python3的数据类型转换分为两种
- 隐式类型转换——自动完成
- 显示类型转换——需要使用类型函数来转换
隐式类型转换¶
- Python会在运算的时候转换成运算过程中最高的数据类型,如整数和浮点数相加,得到的结果是浮点数。
- 数字型和字符串型运算结果会报错,无法进行隐式转换。
显示类型转换¶
使用int(),float(),str()等预定义函数来执行显示类型转换
例如
Example
num_int = 123
num_str = "456"
print("num_int 数据类型为:",type(num_int))
print("类型转换前,num_str 数据类型为:",type(num_str))
num_str = int(num_str) # 强制转换为整型
print("类型转换后,num_str 数据类型为:",type(num_str))
num_sum = num_int + num_str
print("num_int 与 num_str 相加结果为:",num_sum)
print("sum 数据类型为:",type(num_sum))
output
以下几个内置的函数可以执行数据类型之间的转换。这些函数返回一个新的对象,表示转换的值,因此可以用于赋值。
| 函数 | 描述 |
|---|---|
| [int(x ,base]) | 将x转换为一个整数 |
| float(x) | 将x转换到一个浮点数 |
| [complex(real ,imag]) | 创建一个复数 |
| str(x) | 将对象 x 转换为字符串 |
| repr(x) | 将对象 x 转换为表达式字符串 |
| eval(str) | 用来计算在字符串中的有效Python表达式,并返回一个对象 |
| tuple(s) | 将序列 s 转换为一个元组 |
| list(s) | 将序列 s 转换为一个列表 |
| set(s) | 转换为可变集合 |
| dict(d) | 创建一个字典。d 必须是一个 (key, value)元组序列。 |
| frozenset(s) | 转换为不可变集合 |
| chr(x) | 将一个整数转换为一个字符 |
| ord(x) | 将一个字符转换为它的整数值 |
| hex(x) | 将一个整数转换为一个十六进制字符串 |
| oct(x) | 将一个整数转换为一个八进制字符串 |
表格来源于 https://www.runoob.com/python3/python3-type-conversion.html
Python3解释器¶
略
Python3运算符¶
Python3支持以下类型的运算符:
- 算术运算符
- 关系(比较)运算符
- 赋值运算符
- 逻辑运算符
- 位运算符
- 成员运算符
- 身份运算符
- 运算符优先级
算术运算符¶
假设变量a=10,变量b=21
| 运算符 | 描述 | 实例 |
|---|---|---|
| + | 加 - 两个对象相加 | a + b 输出结果 31 |
| - | 减 - 得到负数或是一个数减去另一个数 | a - b 输出结果 -11 |
| * | 乘 - 两个数相乘或是返回一个被重复若干次的字符串 | a * b 输出结果 210 |
| / | 除 - x 除以 y | b / a 输出结果 2.1 |
| % | 取模 - 返回除法的余数 | b % a 输出结果 1 |
| ** | 幂 - 返回x的y次幂 | a**b 为10的21次方 |
| // | 取整除 - 往小的方向取整数 | >>> 9//24>>> -9//2-5 |
比较运算符¶
假设变量a=10,变量b=20
| 运算符 | 描述 | 实例 |
|---|---|---|
| == | 等于 - 比较对象是否相等 | (a == b) 返回 False。 |
| != | 不等于 - 比较两个对象是否不相等 | (a != b) 返回 True。 |
| > | 大于 - 返回x是否大于y | (a > b) 返回 False。 |
| < | 小于 - 返回x是否小于y。所有比较运算符返回1表示真,返回0表示假。 这分别与特殊的变量True和False等价。注意,这些变量名的大写。 |
(a < b) 返回 True。 |
| >= | 大于等于 - 返回x是否大于等于y。 | (a >= b) 返回 False。 |
| <= | 小于等于 - 返回x是否小于等于y。 | (a <= b) 返回 True。 |
赋值运算符¶
假设变量a=10,变量b=20
| 运算符 | 描述 | 实例 |
|---|---|---|
| = | 简单的赋值运算符 | c = a + b 将 a + b 的运算结果赋值为 c |
| += | 加法赋值运算符 | c += a 等效于 c = c + a |
| -= | 减法赋值运算符 | c -= a 等效于 c = c - a |
| *= | 乘法赋值运算符 | c *= a 等效于 c = c * a |
| /= | 除法赋值运算符 | c /= a 等效于 c = c / a |
| %= | 取模赋值运算符 | c %= a 等效于 c = c % a |
| **= | 幂赋值运算符 | c **= a 等效于 c = c ** a |
| //= | 取整除赋值运算符 | c //= a 等效于 c = c // a |
| := | 海象运算符,这个运算符的主要目的是 在表达式中同时进行赋值和返回赋值的值。 Python3.8 版本新增运算符。 |
在这个示例中, 赋值表达式可以避免调用 len() 两次: if (n := len(a)) > 10:print(f"List is({n} elements, expected <= 10)") |
Note
“海象运算符”,它使用:=符号。使用海象运算符可以在一些情况下简化代码,尤其是在需要在表达式中使用赋值结果的情况下,这对于简化循环条件或表达式中的重复计算很有用。例如:
位运算符¶
按位运算符是把数字看做二进制来进行计算的,按位运算法则如下:
下表中变量a为60,b为13二进制格式
| 运算符 | 描述 | 实例 |
|---|---|---|
| & | 按位与运算符:参与运算的两个值, 如果两个相应位都为1,则该位的结果为1,否则为0 |
(a & b) 输出结果 12 , 二进制解释: 0000 1100 |
| | | 按位或运算符:只要对应的二个二进位有一个为1时, 结果位就为1。 |
(a | b) 输出结果 61 , 二进制解释: 0011 1101 |
| ^ | 按位异或运算符:当两对应的二进位相异时,结果为1 | (a ^ b) 输出结果 49 , 二进制解释: 0011 0001 |
| ~ | 按位取反运算符:对数据的每个二进制位取反, 即把1变为0,把0变为1。~x 类似于 -x-1 |
(~a ) 输出结果 -61 , 二进制解释: 1100 0011, 在一个有符号二进制数的补码形式。 |
| << | 左移动运算符:运算数的各二进位全部左移若干位, 由"<<"右边的数指定移动的位数,高位丢弃,低位补0。乘\(2^n\) |
a << 2 输出结果 240 , 二进制解释: 1111 0000 |
| >> | 右移动运算符:运算数的各二进位全部右移若干位, ">>"右边的数指定移动的位数,除\(2^n\) |
a >> 2 输出结果 15 , 二进制解释: 0000 1111 |
逻辑运算符¶
Python语言支持逻辑运算符,以下假设变量 a 为 10, b为 20:
| 运算符 | 逻辑表达式 | 描述 | 实例 |
|---|---|---|---|
| and | x and y | 布尔"与" - 如果 x 为 False,x and y 返回 x 的值,否则返回 y 的计算值。 | (a and b) 返回 20。 |
| or | x or y | 布尔"或" - 如果 x 是 True,它返回 x 的值,否则它返回 y 的计算值。 | (a or b) 返回 10。 |
| not | not x | 布尔"非" - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。 | not(a and b) 返回 False |
成员运算符¶
除了上面的一些运算符之外,Python还支持成员运算符
| 运算符 | 描述 | 实例 |
|---|---|---|
| in | 如果在指定的序列中找到值返回 True,否则返回 False。 | x 在 y 序列中 , 如果 x 在 y 序列中返回 True。 |
| not in | 如果在指定的序列中没有找到值返回 True,否则返回 False。 | x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。 |
Example
#!/usr/bin/python3
a = 10
b = 20
list = [1, 2, 3, 4, 5 ]
if ( a in list ):
print ("1 - 变量 a 在给定的列表中 list 中")
else:
print ("1 - 变量 a 不在给定的列表中 list 中")
if ( b not in list ):
print ("2 - 变量 b 不在给定的列表中 list 中")
else:
print ("2 - 变量 b 在给定的列表中 list 中")
# 修改变量 a 的值
a = 2
if ( a in list ):
print ("3 - 变量 a 在给定的列表中 list 中")
else:
print ("3 - 变量 a 不在给定的列表中 list 中")
output
身份运算符¶
身份运算符用于比较两个对象的存储单元
| 运算符 | 描述 | 实例 |
|---|---|---|
| is | is 是判断两个标识符是不是引用自一个对象 | x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False |
| is not | is not 是判断两个标识符是不是引用自不同对象 | x is not y , 类似 id(x) != id(y)。 如果引用的不是同一个对象则返回结果 True,否则返回 False。 |
Note
is 与 == 区别:is 用于判断两个变量引用对象是否为同一个, == 用于判断引用变量的值是否相等。
运算符优先级¶
| 运算符 | 描述 |
|---|---|
(expressions...),[expressions...], {key: value...}, {expressions...} |
圆括号的表达式 |
x[index], x[index:index], x(arguments...), x.attribute |
读取,切片,调用,属性引用 |
| await x | await 表达式 |
** |
乘方(指数) |
+x, -x, ~x |
正,负,按位非 NOT |
*, @, /, //, % |
乘,矩阵乘,除,整除,取余 |
+, - |
加和减 |
<<, >> |
移位 |
& |
按位与 AND |
^ |
按位异或 XOR |
| |
按位或 OR |
in,not in, is,is not, <, <=, >, >=, !=, == |
比较运算,包括成员检测和标识号检测 |
not x |
逻辑非 NOT |
and |
逻辑与 AND |
or |
逻辑或 OR |
if -- else |
条件表达式 |
lambda |
lambda 表达式 |
:= |
赋值表达式 |
Note
注意:Python3 已不支持 <> 运算符,可以使用 !=代替。
