一、条件控制语句
Python 条件语句是通过一条或多条语句的执行结果(结果是 true 或 false) 来决定代码块的执行。
- 语法
if 表达式1:语句1elif 表达式2:语句2else:语句3
需要注意的是:
- 每个条件后面需要使用
:,表示接下来是满足条件后要执行的语句; python使用缩进来划分语句块,相同缩进数的语句在一起组成一个语句块;python中没有switch ... case ...语句。
if嵌套
if 表达式1:语句1if 表达式1-1:语句1-1elif 表达式1-2:语句1-2else:语句elif 表达式2:语句2else:语句3
- 代码
import randomanswer = random.randint(1,10)temp = input('请输入一个数字:')guess = int(temp)if guess == answer:print('你猜对了')breakelse:print('你猜错了')print('游戏结束。。。')
二、循环语句
while 循环
while 判断条件:执行语句# while 循环使用 elsewhile 判断条件:执行语句else:执行语句
for 循环
for 循环可以遍历任何可迭代对象。例如:列表、元组、集合或者字符串。
for <variable> in <sequence>:执行语句
range()函数
如果需要遍历数字序列,可以使用内置函数 range。例如:
for i in range(10):print(i)0123456789# 也可以定义指定区间进行遍历for i in range(2,6):print(i)2345# 也可以指定增量进行循环(增量也叫步长,可以是正数或者负数)for i in range(1,10,2):print(i)13579
break 和 continue 语句
break 语句可以跳出当前的 for 循环或者 while 循环。如果从 for 或者 while 循环中跳出,对应的 else 语句将不会被执行。
contine 语句用于告诉 python,跳过当前循环中的剩余语句,继续执行下一个循环。
三、迭代器与生成器
迭代是 python最强大的功能之一,是访问集合元素的一种方式。她可以记住遍历的位置的对象,从集合的第一个元素开始访问,直到所有的元素被访问完结束。并且只能往前不会后退。
迭代器有两个基本的方法:iter() 和 next()。字符串,列表或元组对象都可用于创建迭代器。
list = [1,2,3,4,5]res = iter(list)for x in res:print(x)12345
四、模块、命名空间和作用域
模块
模块是一个包含所有你定义的函数和变量的文件,其后缀名是 .py。模块可以被别的程序引入,以使用该模块中的函数等功能,这也是使用 python 标准库的方法。引用模块可以通过如下的方式:
import module语句from ... import语句
命名空间
命名空间 (namespace) 是从名称到对象的映射,大部分的命名空间都是通过 python 字典来实现的。命名空间提供了在项目中避免名字冲突的一种方法。各个命名空间是独立的,没有任何关系的,所以一个命名空间中不能有重名,但不同的命名空间是可以重名而没有任何影响。
命名空间有三种类型:
- 内置名称:
python语言内置的名称。例如:函数名称abs、char和异常名称BaseException、Exception等; - 全局名称: 模块中定义的名称,记录了模块的变量,包括函数、类、其它导入的模块、模块级的变量和常量;
- 局部名称: 函数中定义的名称,记录了函数的变量,包括函数的参数和局部定义的变量。(类中定义的也是)。
命名空间的查找顺序:局部的命名空间去 -> 全局命名空间 -> 内置命名空间
五、File
open 方法
open() 方法用于打开一个文件,并返回文件对象,在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 OSError。使用 **open()** 方法,一定要保证文件对象关闭。即调用 **close()** 方法。
open()方法常用的形式是接收两个参数:文件名和模式:open(fileName, mode='r')open()方法的完整语法格式为:open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
参数说明:
file: 必需,文件路径(相对或者绝对路径)。mode: 可选,文件打开模式buffering: 设置缓冲encoding: 一般使用utf8errors: 报错级别newline: 区分换行符closefd: 传入的file参数类型opener:设置自定义开启器,开启器的返回值必须是一个打开的文件描述符。
mode 参数
| 模式 | 描述 |
|---|---|
t |
文本模式 (默认)。 |
x |
写模式,新建一个文件,如果该文件已存在则会报错。 |
b |
二进制模式。 |
+ |
打开一个文件进行更新(可读可写)。 |
r |
以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb |
以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。 |
r+ |
打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ |
以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。 |
w |
打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb |
以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
w+ |
打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。 |
wb+ |
以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。 |
a |
打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab |
以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ |
打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ |
以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
file 对象常用函数
| 方法 | 功能描述 |
|---|---|
file.close() |
关闭文件。关闭后文件不能再进行读写操作。 |
file.flush() |
刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 |
file.fileno() |
返回一个整型的文件描述符(file descriptor FD整型), 可以用在如os模块的 read方法等一些底层操作上。 |
file.isatty() |
如果文件连接到一个终端设备返回 True,否则返回 False。 |
file.read([size]) |
从文件读取指定的字节数,如果未给定或为负则读取所有。 |
file.readline([size]) |
读取整行,包括 "\\n"字符。 |
file.readlines([sizeint]) |
读取所有行并返回列表,若给定 sizeint>0,返回总和大约为 sizeint字节的行, 实际读取值可能比 sizeint较大, 因为需要填充缓冲区。 |
file.seek(offset[, whence]) |
移动文件读取指针到指定位置 |
file.tell() |
返回文件当前位置。 |
file.truncate([size]) |
从文件的首行首字符开始截断,截断文件为 size个字符,无 size表示从当前位置截断;截断之后后面的所有字符被删除,其中 windows系统下的换行代表 2 个字符大小。 |
file.write(str) |
将字符串写入文件,返回的是写入的字符长度。 |
file.writelines(sequence) |
向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。 |
