目录
我们可以把 Python 当成一个计算器,来进行一些算术运算。
- print(1 + 2 - 3) //0
- print(1 + 2 * 3) //7
- print(1 + 2 / 3) //1.6666666666667

注意:
形如 1 + 2 - 3 这样是算式,在编程语言中称为表达式,算式的运算结果,称为表达式的返回值。其中 1 2 3 这种称为字面值常量,+ - * / 这种称为运算符或者操作符
注意:熟悉C/Java的人可能认为,2/3结果为 0 (小数部分被截断)。但是在Python中得到的结果则是一个小数。更符合日常使用的直觉
示例:给定四个分数,67.5 89.0 12.9 32.2。编写代码,求这四个分数的平均数
print( (67.5 + 89.0 + 12.9 + 32.2) / 4 )
有的时候,我们需要进行的计算可能更复杂一些,需要把一些计算的中间结果保存起来。这个时候就需要用到变量。
示例:给定四个分数,67.5 89.0 12.9 32.2。编写代码,求这四个分数的方差。(方差的计算过程:取每一项,减去平均值,计算平方,再求和,最后除以 (项数 - 1))
在这个代码中,就需要先计算这四个数字的平均值,然后再计算方差。这就需要把计算的平均值使用变量保存起来
- avg = (67.5 + 89.0 + 12.9 + 32.2) / 4
- total = (67.5 - avg) ** 2 + (89.0 - avg) ** 2 + (12.9 - avg) ** 2 + (32.2 - avg)
- ** 2
- result = total / 3
- print(result)
注意:avg, total, result 均为变量. ** 在 Python 中表示乘方运算. ** 2 即为求平方
就像计算器中的 M 键功能类似,通过变量就可以保存计算过程中的中间结果
只不过,计算器一般只能保存一个数据,而在 Python 代码中可以创建任意多的变量来随心所欲的保存很多很多的数据。
变量可以视为是一块能够容纳数据的空间。这个空间往往对应到 "内存" 这样的硬件设备上

PS:我们可以把内存想像成是一个宿舍楼,这个宿舍楼上有很多的房间,每个房间都可以存放数据。
衡量内存的一个重要指标就是内存空间的大小,比如我的电脑内存是 32GB。这个数字越大,意味着内存的存储空间就越大,能够存放的数据(变量) 就越多
a = 10
创建变量的语句非常简单,其中
注意:变量的名字要遵守一定规则。
硬性规则(务必遵守):
- 变量名由数字字母下划线构成。
- 数字不能开头。
- 变量名不能和 "关键字" 重复。
- 变量名大小写敏感。num 和 Num 是两个不同的变量名。
软性规则(建议遵守) :
- 变量名使用有描述性的单词来表示,尽量表达出变量的作用。
- 一个变量名可以由多个单词构成,长一点没关系,但是含义要清晰。
- 当变量名包含多个单词的时候,建议使用 "驼峰命名法"。形如 totalCount,personInfo 这种,除了首个单词外,剩余单词首字母大写。
数学上,变量通常使用 x, y, z 这种简单的英文字母或者拉丁字母表示,但是在编程中不建议这样使用。原因是编程中,一个程序里通常会同时创建出很多个变量,如果只是使用单个字母表示,在变量多了的时候,就很难记住哪个变量是干啥的,从而给维护程序带来了一定的困难。因此我们更建议使用带有明确描述性的名字,来表示变量的用途。
读取变量的值:
- a = 10
- print(a)
修改变量的值:
- a = 20
- print(a)
注意:在 Python 中,修改变量也是使用 = 运算,看起来和定义变量没有明显区别
当然,也可以用一个变量的值赋给另外一个变量:
- a = 10
- b = 20
- a = b
- print(a)
- print(b)
变量里面存储的不仅仅是数字,还可以存储其它种类的数据。为了区分不同种类的数据,引入了 "类型" 这样的概念。
注意:和C/Java等语言不同。Python 变量的类型不需要显式指定,而是在赋值的时候确定的。
- a = 10
- print(type(a))

PS:type 和 print 类似,也是 python 内置的函数。可以使用 type 来查看一个变量的类型
注意:和 C++ / Java 等语言不同,Python 的 int 类型变量,表示的数据范围是没有上限的。只要内存足够大,理论上就可以表示无限大小的数据。
- a = 0.5
- print(type(a))
注意:和 C++ / Java 等语言不同。Python 的小数只有 float 一种类型。没有 double 类型。但是实际上 Python 的 float 就相当于 C++ / Java 的 double。表示双精度浮点数
- a = 'hello'
- print(type(a))

使用 ' ' 或者 " " 引起来的,称为字符串。可以用来表示文本。
注意:在 Python 中,单引号构成的字符串和双引号构成的字符串没有区别。 'hello' 和 "hello" 是 完全等价的。
可以使用 len 函数来获取字符串的长度:
- a = 'hello'
- print(len(a))
可以使用 + 针对两个字符串进行拼接:
- a = 'hello'
- b = 'world'
- print(a + b)
↑ 此处是两个字符串相加。不能拿字符串和整数/浮点数相加。
字符串作为开发中最常用到的数据类型,支持的操作方式也是非常丰富的。此处暂时不详细展开
布尔类型是一个特殊的类型,取值只有两种,True (真) 和 False (假)。
PS: 布尔类型也是数学上的一个概念。我们初中就学过一个概念叫做 "命题" ,进一步的就可以判定命题的真假。
- a = True
- print(type(a))
- b = False
- print(type(b))
布尔类型在咱们后续进行逻辑判断的时候,是非常有用的。
除了上述类型之外,Python中还有 list tuple dict 自定义类型 等等。
例如 float 类型在内存中占据 8 个字节。
例如 int / float 类型的变量,可以进行 + - * / 等操作。
而 str 类型的变量,只能进行 + (并且行为是字符串拼接),不能进行 - * / ,但是还能使用 len 等其他操作。
总结:类型系统其实是在对变量进行 "归类"。相同类型的变量(数据) 往往具有类似的特性和使用规则。
在 Python 中,一个变量是什么类型,是可以在 "程序运行" 过程中发生变化的。这个特性称为 "动态类型" 。
- a = 10
- print(type(a))
- a = 'hello'
- print(type(a))
在程序执行过程中,a 的类型刚开始是 int,后面变成了 str。C++/Java 这样的语言则不允许这样的操作。一个变量定义后类型就是固定的了。这种特性则称为 "静态类型"。
动态类型特性是一把双刃剑:
注释是一种特殊的代码,它不会影响到程序的执行,但是能够起到解释说明的作用,能够帮助程序猿理解程序代码的执行逻辑.。
PS:写代码是一件比较烧脑的事情,读代码同样也非常烧脑。相比于一板一眼的代码,一些口语化的描述能更好的帮助程序猿理解程序。
- # 计算 4 个数字 67.5, 89.0, 12.9, 32.2 的方差
- avg = (67.5 + 89.0 + 12.9 + 32.2) / 4
- total = (67.5 - avg) ** 2 + (89.0 - avg) ** 2 + (12.9 - avg) ** 2 + (32.2 - avg)
- ** 2
- result = total / 3
- print(result)
形如上述代码,如果没有注释,直接阅读,是不容易 get 到代码的含义是计算方差。但是通过加了一行注释解释一下,就让人一目了然了。
Python 中有两种风格的注释
使用 # 开头的行都是注释
# 这是一行注释。
使用三引号引起来的称为 "文档字符串",也可以视为是一种注释。
- """
- 这是文档字符串
- 这是文档字符串
- """
程序需要和用户进行交互
输入输出的最基本的方法就是控制台。用户通过控制台输入一些字符串,程序再通过控制台打印出一些字符串。
PyCharm 运行程序,下方弹出的窗口就可以视为是控制台。
windows自带的 cmd 程序,也可以视为是控制台。
输入输出的最常见方法是图形化界面。如我们平时用到的 QQ、浏览器、steam 等,都不需要用户输入命令,而只是通过鼠标点击窗口点击按钮的方式来操作。Python 当然也可以用来开发图形化界面的程序。但是图形化程序开发本身是一个大话题。暂时难以解释清楚。
Python 使用 print 函数输出到控制台.
print('hello')
不仅能输出一个字符串,还可以输出一个其他类型的变量。
- a = 10
- print(a)
- b = True
- print(b)
更多的时候,我们希望能够输出的内容是混合了字符串和变量的。
示例:输出 num = 10
- num = 10
- print(f'num = {num}')
注意:使用 f 作为前缀的字符串,称为 f-string 里面可以使用 { } 来内嵌一个其他的变量/表达式。
PS:Python 中还支持其他的格式化字符串的方法,咱们此处只了解这个最简单的即可。其他的暂时不做介绍。
python 使用 input 函数,从控制台读取用户的输入。
- num = 0
- num = input('请输入一个整数: ')
- print(f'你输入的整数是 {num}')
注意:
- a = input('请输入第一个整数: ')
- b = input('请输入第二个整数: ')
- print(f'a + b = {a + b}')
此处的结果是字符串拼接,不是算术运算。如果要想进行算术运算,需要先转换类型。
- a = input('请输入第一个整数: ')
- b = input('请输入第二个整数: ')
- a = int(a)
- b = int(b)
- print(f'a + b = {a + b}')

通过int( )把变量转成了int类型。类似的,使用float( ),bool( ),str( )等可以完成对应的类型转换。
代码示例:输入 4 个小数,求 4 个小数的平均值
- a = input('请输入第一个数字: ')
- b = input('请输入第二个数字: ')
- c = input('请输入第三个数字: ')
- d = input('请输入第四个数字: ')
- a = float(a)
- b = float(b)
- c = float(c)
- d = float(d)
- avg = (a + b + c + d) / 4
- print(f'平均值: {avg}')
此处为了输入4个数字,执行了四次 input。如果是读取任意多个数字怎么办呢? 这个时候就需要用到循环了。
像 + - * / % ** // 这种进行算术运算的运算符,称为算术运算符
print(10 / 0)
异常是编程语言中的一种常见机制,表示程序运行过程中,出现了一些 "意外情况",导致程序不能继续往下执行了。
print(1 / 2)
print(5 % 2)
- print(4 ** 2)
- print(4 ** 0.5)

- print(7 // 2)
- print(-7 // 2)
像 < >= == != 这一系列的运算符称为关系运算符,它们是在比较操作数之间的关系。
其中
(1) 如果关系符合,则表达式返回 True。如果关系不符合,则表达式返回 False。
- a = 10
- b = 20
- print(a < b)
- print(a <= b)
- print(a > b)
- print(a >= b)
- print(a == b)
- print(a != b)
(2) 关系运算符不光针对整数/浮点数进行比较,还能针对字符串进行比较。
- a = 'hello'
- b = 'world'
- print(a < b)
- print(a <= b)
- print(a > b)
- print(a >= b)
- print(a == b)
- print(a != b)
注意:
关于字典序:
想象一个英文词典,上面的单词都是按照字母顺序排列。如果首个字母相同,就比较第二个字母。(就 比如著名单词 abandon)。我们认为一个单词在词典上越靠前,就越小,越靠后, 就越大。
(3) 对于浮点数来说,不要使用 == 判定相等。
print(0.1 + 0.2 == 0.3)
注意:浮点数在计算机中的表示并不是精确的。在计算过程中,就容易出现非常小的误差。
- print(0.1)
- print(0.2)
- print(0.3)
- print(0.1 + 0.2)

可以看到,0.1 + 0.2 的结果并非是 0.3,而是带了个小尾巴。虽然这个尾巴非常小了,但是 == 是锱铢必较的。仍然会导致 == 的结果为 False。
不止是 Python 如此,主流编程语言都是如此,这个是 IEEE754 标准规定的浮点数格式所引入的问题。
正确的比较方式:不再严格比较相等了,而是判定差值小于允许的误差范围。
- a = 0.1 + 0.2
- b = 0.3
- print(-0.000001 < (a - b) < 0.000001)
像 and or not 这一系列的运算符称为逻辑运算符。
此处说的 "并且" 和 "或者",就是我们日常生活中使用的 "并且" 和 "或者"。
- a = 10
- b = 20
- c = 30
- print(a < b and b < c) //True
- print(a < b and b > c) //False
- print(a > b or b > c) //False
- print(a < b or b > c) //True
- print(not a < b) //False
- print(not a > b) //True
一种特殊写法:a < b and b < c 这个操作等价于 a < b < c。这个设定和大部分编程语言都不相同
和其他编程语言类似,Python 也存在短路求值的规则。
- print(10 > 20 and 10 / 0 == 1) //False
- print(10 < 20 or 10 / 0 == 1) //True
验证:上述代码没有抛出异常,说明右侧的除以 0 操作没有真正执行。
a = b = 10
a, b = 10, 20
代码实例:交换两个变量
基础写法:
- a = 10
- b = 20
-
- tmp = a
- a = b
- b = tmp
基于多元赋值:
- a = 10
- b = 20
-
- a, b = b, a
Python 还有一些复合赋值运算符。例如 += -= *= /= %=
其中 a += 1 等价于 a = a + 1。其他复合赋值运算符也是同理。
- a = 10
- a = a + 1
- print(a)
- b = 10
- b += 1
- print(b)
注意:像 C++ / Java 中,存在 ++ -- 这样的自增/自减运算符。Python 中则不支持这种运算。如果需要使用,则直接使用 += 1 或者 -= 1
++ -- 最大的问题就是容易分不清前置和后置的区别。这一点 Python 语法在设计的时候就进行了规避,避免出现这种不直观,并且容易混淆的语法。
其它:
除了上述之外,Python 中还有一些运算符,比如 身份运算符 (is, is not),成员运算符 (in, not in),位运算符 ( & | ~ ^ >) 等。