Python基础语法
文章目录
- Python基础语法
- 基础语法
- 变量的语法
- (1) 定义变量
- (2) 使用变量
- 变量的类型
- (1) 整数
- (2) 浮点数(小数)
- (3) 字符串
- (4) 布尔
- (5) 其他
- 动态类型特性
- 输入输出
- 注释
- 通过控制台输出
- 通过控制台输入
- 运算符
- 算术运算符
- 关于除法
- // 取整除法
- 关系运算符
- 逻辑运算符
- 关于短路求值
- 其他...
- 顺序语句
- 条件语句
- 语法格式
- (1) if
- (2) if - else
- (3) if - elif - else
- 缩进和代码块
- 练习
- 奇数判断
- 正负数判断
- 闰年判断
- 空语句 pass
- 循环语句
- while 循环
- 练习
- 打印 1-10 的整数
- 计算 1-100 的和
- 计算 5 的阶乘
- 求 1! + 2! + 3! + 4! + 5!
- for 循环
- 打印 1-10
- 打印 2, 4, 6, 8, 10
- 打印 10-1
- 求 1 - 100 的和
- continue
- break
- 打印 10-1
- 求 1 - 100 的和
- continue
- break
基础语法
求方差
给定四个分数, 67.5, 89.0, 12.9, 32.2 , 编写代码, 求这四个分数的方差.
PS: 方差的计算过程: 取每一项, 减去平均值, 计算平方, 再求和, 最后除以 (项数 - 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)
- ** 在 Python 中表示乘方运算. ** 2 即为求平方. **3即求立方。
变量的语法
(1) 定义变量
a = 10
创建变量的语句非常简单, 其中
- a 为变量名. 当我们创建很多个变量的时候, 就可以用名字来进行区分.
- = 为赋值运算符, 表示把 = 右侧的数据放到 = 左侧的空间中
注意:
变量的名字要遵守一定规则. 硬性规则(务必遵守)
- 变量名由数字字母下划线构成.
- 数字不能开头.
- 变量名不能和 “关键字” 重复.
- 变量名大小写敏感. num 和 Num 是两个不同的变量名
软性规则(建议遵守)
- 变量名使用有描述性的单词来表示, 尽量表达出变量的作用.
- 一个变量名可以由多个单词构成, 长一点没关系, 但是含义要清晰.
- 当变量名包含多个单词的时候, 建议使用 “驼峰命名法”. 形如 totalCount , personInfo 这种, 除 了首个单词外, 剩余单词首字母大写. 或者“蛇形命名法”total_count , person_info
数学上, 变量通常使用 x, y, z 这种简单的英文字母或者拉丁字母表示. 但是在编程中不建议这样使 用. 原因是编程中, 一个程序里通常会同时创建出很多个变量. 如果只是使用单个字母表示, 在变量多了 的时候, 就很难记住哪个变量是干啥的, 从而给维护程序带来了一定的困难. 因此我们更建议使用带 有明确描述性的名字, 来表示变量的用途.
(2) 使用变量
读取变量的值
a = 10
print(a)
修改变量的值
a = 20
print(a)
注意: 在 Python 中, 修改变量也是使用 = 运算, 看起来和定义变量没有明显区别
当然, 也可以用一个变量的值赋给另外一个变量
a = 10
b = 20
a = b
print(a)
print(b)
变量的类型
变量里面存储的不仅仅是数字, 还可以存储其它种类的数据. 为了区分不同种类的数据, 我们引入了 “类型” 这样的概念.
注意: 和 C++ / Java 等语言不同, Python 变量的类型不需要显式指定, 而是在赋值的时候确定的.
(1) 整数
a = 10
print(type(a))
PS: type 和 print 类似, 也是 python 内置的函数. 可以使用 type 来查看一个变量的类型.
注意: 和 C++ / Java 等语言不同, Python 的 int 类型变量, 表示的数据范围是没有上限的. 只要内存足够大, 理论上就可以表示无限大小的数据. 因此Python里没有long类型,byte和short也不存在
(2) 浮点数(小数)
a = 0.5
print(type(a))
注意: 和 C++ / Java 等语言不同, Python 的小数只有 float 一种类型, 没有 double 类型. 但是实际上 Python 的 float 就相当于 C++ / Java 的 double, 表示双精度浮点数.
PS: 关于单精度浮点数和双精度浮点数的问题, 我们此处不做过多讨论. 大家只要知道, 相比于单精 度浮点数, 双精度浮点数占用的内存空间更多, 同时表示的数据精度更高即可(大概精确到小数点后 15 位).
(3) 字符串
a = 'hello'
print(type(a))
使用 ’ ’ 或者 " " 引起来的, 称为 字符串. 可以用来表示文本.
注意: 在 Python 中, 单引号构成的字符串和双引号构成的字符串, 没有区别. ‘hello’ 和 “hello” 是 完全等价的
可以使用 len 函数来获取字符串的长度.
a = 'hello'
print(len(a))
可以使用 + 针对两个字符串进行拼接
a = 'hello'
b = 'world'
print(a + b)
此处是两个字符串相加. 不能拿字符串和整数/浮点数相加.
字符串作为开发中最常用到的数据类型, 支持的操作方式也是非常丰富的. 此处暂时不详细展开.
(4) 布尔
布尔类型是一个特殊的类型, 取值只有两种, True (真) 和 False (假)
PS: 布尔类型也是数学上的一个概念. 我们初中就学过一个概念叫做 “命题” , 进一步的就可以判定 命题的真假.
a = True
print(type(a))
b = False
print(type(b))
布尔类型在咱们后续进行逻辑判断的时候, 是非常有用的.
(5) 其他
除了上述类型之外, Python 中还有 list, tuple, dict, 自定义类型 等等. 我们后续再介绍.
动态类型特性
在 Python 中, 一个变量是什么类型, 是可以在 “程序运行” 过程中发生变化的. 这个特性称为 “动态类型” .
a = 10
print(type(a))
a = 'hello'
print(type(a))
在程序执行过程中, a 的类型刚开始是 int, 后面变成了 str.
C++/Java 这样的语言则不允许这样的操作. 一个变量定义后类型就是固定的了. 这种特性则称为 “静态类型”.
动态类型特性是一把双刃剑.
- 对于中小型程序, 可以大大的解约代码量(比如写一段代码就可以同时支持多种类型).
- 对于大型程序, 则提高了模块之间的交互成本. (程序猿 A 提供的代码难以被 B 理解).
输入输出
注释
通过控制台输出
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}')
注意:
- input 的参数相当于一个 “提示信息”, 也可以没有.
- input 的返回值就是用户输入的内容. 是字符串类型.
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}')
代码示例: 输入 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(7 // 2)
print(-7 // 2)
关系运算符
关系运算符不光针对整数/浮点数进行比较, 还能针对字符串进行比较
a = 'hello'
b = 'world'
print(a < b)
print(a <= b)
print(a > b)
print(a >= b)
print(a == b)
print(a != b)
注意:
- 直接使用 == 或者 != 即可对字符串内容判定相等. (这一点和 C / Java 不同).
- 字符串比较大小, 规则是 “字典序”
关于字典序:
想象一个英文词典, 上面的单词都是按照字母顺序排列. 如果首个字母相同, 就比较第二个字母. (就 比如著名单词 abandon).
我们认为一个单词在词典上越靠前, 就越小. 越靠后, 就越大.
逻辑运算符
像 and or not 这一系列的运算符称为 逻辑运算符.
-
and 并且. 两侧操作数均为 True, 最终结果为 True. 否则为 False. (一假则假)
-
or 或者. 两侧操作数均为 False, 最终结果为 False. 否则为 True. (一真则真)
-
not 逻辑取反. 操作数本身为 True, 则返回 False. 本身为 False, 则返回 True.
此处说的 “并且” 和 “或者”, 就是我们日常生活中使用的 “并且” 和 “或者”.
a = 10
b = 20
c = 30
print(a < b and b < c)
print(a < b and b > c)
print(a > b or b > c)
print(a < b or b > c)
print(not a < b)
print(not a > b)
一种特殊写法
a < b and b < c 这个操作等价于 a < b < c . 这个设定和大部分编程语言都不相同.
关于短路求值
和其他编程语言类似, Python 也存在短路求值的规则.
- 对于 and, 如果左侧表达式为 False, 则整体一定为 False, 右侧表达式不再执行.
- 对于 or, 如果左侧表达式为 True, 则整体一定为 True, 右侧表达式不再执行.
print(10 > 20 and 10 / 0 == 1)
print(10 < 20 or 10 / 0 == 1)
上述代码没有抛出异常, 说明右侧的除以 0 操作没有真正执行.
其他…
除了上述之外, Python 中还有一些运算符, 比如 身份运算符 (is, is not), 成员运算符 (in, not in), 位运算符 ( & | ~ ^ << >>) 等.
顺序语句
默认情况下, Python 的代码执行顺序是按照从上到下的顺序, 依次执行的.
print("1")
print("2")
print("3")
执行结果一定为 “123”, 而不会出现 “321” 或者 “132” 等. 这种按照顺序执行的代码, 我们称为 顺序语句.
这个顺序是很关键的. 编程是一件明确无歧义的事情. 安排好任务的顺序, 计算机才能够正确的进行 执行.
就好像人生的顺序, 是上学, 工作, 结婚, 生子. 一旦这里的顺序乱了, 就很麻烦
条件语句
语法格式
Python 中使用 if else 关键字表示条件语句.
(1) if
if expression:
do_something1
do_something2
next_something
如果 expression 值为 True, 则执行 do_something1,do_something2, next_something
如果 expression 值为 False, 则只执行 next_something, 不执行 do_something1, do_something2
(2) if - else
if expression:
do_something1
else:
do_something2
如果 expression 值为 True, 则执行 do_something1
如果 expression 值为 False, 则执行 do_something2
(3) if - elif - else
if expression1:
do_something1
elif expression2:
do_something2
else:
do_something3
如果 expression1 值为 True, 则执行 do_something1
如果 expression1 值为 False, 并且 expression2 为 True 则执行 do_something2
如果 expression1 值为 False, 并且 expression2 为 False 则执行 do_something3
注意: Python中的条件语句写法, 和很多编程语言不太一样.
- if 后面的条件表达式, 没有 ( ), 使用 : 作为结尾.
- if / else 命中条件后要执行的 “语句块”, 使用 缩进 (通常是 4 个空格或者 1 个 tab)来表示, 而不是 { }
- 对于多条件分支, 不是写作 else if, 而是 elif (合体了).
缩进和代码块
代码块 指的是一组放在一起执行的代码.
在 Python 中使用缩进表示代码块. 不同级别的缩进, 程序的执行效果是不同的.
# 代码1
a = input("请输入一个整数: ")
if a == "1":
print("hello")
print("world")
# 代码2
a = input("请输入一个整数: ")
if a == "1":
print("hello")
print("world")
注意上述代码的区别.
在代码1 中, print(“world”) 有一级缩进, 这个语句属于 if 内的代码块, 意味着条件成立, 才执行, 条件 不成立, 则不执行.
在代码2 中, print(“world”) 没有缩进, 这个语句是 if 外部的代码, 不属于 if 内部的代码块. 意味着条件 无论是否成立, 都会执行.
另外, 代码块内部还可以嵌套代码块.
a = input("请输入第一个整数: ")
b = input("请输入第二个整数: ")
if a == "1":
if b == "2":
print("hello")
print("world")
print("python")
在这个代码中,
- print(“hello”) 具有两级缩进, 属于 if b == “2” 条件成立的代码块.
- print(“world”) 具有一级缩进, 属于 if a == “1” 条件成立的代码块.
- print(“python”) 没有缩进, 无论上述两个条件是否成立, 该语句都会执行.
基于缩进的方式表示代码块, 带来的好处就是强制要求程序猿要写明确的缩进, 来明确代码之间的相对关系. 如果缩进书写的不对, 则直接报错.
像 C++ / Java 这些语言, 即使完全不写缩进, 语法也不会报错. 代码可读性就比较差.
同时, 带来的坏处就是, 如果缩进层次比较多, 就容易分不清楚某个语句属于哪个层级.
if a == 1:
if b == 2:
if c == 3:
if d == 4:
if e == 5:
if f == 6:
if g == 7:
print("hello")
print("1")
print("2")
请问, 上述代码中的 print(“1”) 和 print(“2”) 属于哪一级缩进?
练习
奇数判断
a = int(intput("请输入一个整数: "))
if a % 2 == 0:
print("偶数")
else:
print("奇数")
正负数判断
a = int(input("请输入一个整数: "))
if a > 0:
print("正数")
elif a < 0:
print("负数")
else:
print("为 0")
闰年判断
year = int(input("请输入年份: "))
if year % 100 == 0:
# 判定世纪闰年
if year % 400 == 0:
print("闰年")
else:
print("平年")
else:
# 判定普通闰年
if year % 4 == 0:
print("闰年")
else:
print("平年")
year = int(input("请输入年份: "))
if (year % 100 != 0 and year % 4 == 0) or year % 400:
print("闰年")
else:
print("平年")
空语句 pass
代码示例: 输入一个数字, 如果数字为 1, 则打印 hello
a = int(input("请输入一个整数:"))
if a == 1:
print("hello")
这个代码也可以等价写成
a = int(input("请输入一个整数:"))
if a != 1:
pass
else:
print("hello")
其中 pass 表示 空语句, 并不会对程序的执行有任何影响, 只是占个位置, 保持 Python 语法格式符合要 求.
如果代码写作
a = int(input("请输入一个整数:")) if a != 1: else: print("hello")
程序是不符合 Python 语法的, 会直接报错.
循环语句
有些操作是需要反复执行的. 这种就需要使用循环.
while 循环
基本语法格式
while 条件:
循环体
- 条件为真, 则执行循环体代码.
- 条件为假, 则结束循环.
练习
打印 1-10 的整数
num = 1
while num <= 10:
print(num)
num += 1
计算 1-100 的和
sum = 0
num = 1
while num <= 100:
sum += num
num += 1
print(sum)
计算 5 的阶乘
result = 1
n = 1
while n <= 5:
result *= n
n += 1
print(result)
求 1! + 2! + 3! + 4! + 5!
num = 1
sum = 0
while num <= 5:
factorResult = 1
i = 1
while i <= num:
factorResult *= i
i += 1
sum += factorResult
num += 1
print(sum)
这个程序用到了两重循环. 也就是在循环语句中也可以套循环.
for 循环
基本语法格式
for 循环变量 in 可迭代对象:
循环体
注意:
-
python 的 for 和其他语言不同, 没有 “初始化语句”, “循环条件判定语句”, “循环变量更新语句”, 而是 更加简单
-
所谓的 “可迭代对象”, 指的是 “内部包含多个元素, 能一个一个把元素取出来的特殊变量”
打印 1-10
for i in range(1, 11):
print(i)
- 使用 range 函数, 能够生成一个可迭代对象. 生成的范围是 [1, 11), 也就是 [1, 10]
打印 2, 4, 6, 8, 10
for i in range(2, 12, 2):
print(i)
- 通过 range 的第三个参数, 可以指定迭代时候的 “步长”. 也就是一次让循环变量加几.
打印 10-1
for i in range(10, 0, -1):
print(i)
- range 的 步长也可以设定成负数.
求 1 - 100 的和
sum = 0
for i in range(1, 101):
sum += i
print(sum)
continue
continue 表示结束这次循环, 进入下次循环.
代码示例: 模拟吃包子. 吃第 3 个包子的时候吃出了一只虫.
for i in range(1, 6):
if i == 3:
continue
print(f"吃完第 {i} 个包子")
break
break 表示结束整个循环
代码示例: 模拟吃包子. 吃第 3 个包子的时候吃出了半只虫.
for i in range(1, 6):
if i == 3:
break
print(f"吃完第 {i} 个包子")
代码示例: 输入若干个数字, 求平均值. 使用 “分号” 作为结尾.
sum = 0
count = 0
while True:
num = input("请输入数字:")
if num == ';':
break
num = float(num)
sum += num
count += 1
print(sum / count)
打印 10-1
for i in range(10, 0, -1):
print(i)
- range 的 步长也可以设定成负数.
求 1 - 100 的和
sum = 0
for i in range(1, 101):
sum += i
print(sum)
continue
continue 表示结束这次循环, 进入下次循环.
代码示例: 模拟吃包子. 吃第 3 个包子的时候吃出了一只虫.
for i in range(1, 6):
if i == 3:
continue
print(f"吃完第 {i} 个包子")
break
break 表示结束整个循环
代码示例: 模拟吃包子. 吃第 3 个包子的时候吃出了半只虫.
for i in range(1, 6):
if i == 3:
break
print(f"吃完第 {i} 个包子")
代码示例: 输入若干个数字, 求平均值. 使用 “分号” 作为结尾.
sum = 0
count = 0
while True:
num = input("请输入数字:")
if num == ';':
break
num = float(num)
sum += num
count += 1
print(sum / count)