(七) 文件操作
7.1常见的文件类型:
- txt
- csv
- json
- html
7.2文件操作的流程
- 打开—>open
- 读写—>read()/write()
- 关闭—>close()
序号 | 用途 | 方法 | 功能 |
---|---|---|---|
1 | 打开/关闭文件 | f=open(file) | 打开文件 |
close() | 关闭文件 | ||
2 | 读写文件内容 | f.read([size]) | 从文件中读取指定字节数;若未指定,读取所有 |
f.readline([size]) | 读取整行,包括“\n” | ||
f.readlines([size]) | 读取所有行,并返回列表 | ||
f.write(str) | 将字符串写入文件,并返回字符串长度 | ||
f.writelines(seq) | 向文件写入一个序列字符串列表。如果需要换行,需要自己加入换行代码 | ||
f.flush() | 刷新新文件缓冲,直接把内部缓冲中的数据写入文件 | ||
3 | 文件的定位 | f.seek(offset) | 设置文件当前位置,即指针位置 |
f.tell | 返回文件当前位置,即指针位置 |
7.3文件的打开与关闭
内置函数:open(),创建一个file对象,之后才可以用它调用相关的方法
格式:
file_object = open(file,[,mode],[,encoding="utf-8"],[,buffering])
解释:
- file_object—>open()返回的文件对象
- file—>要打开的文件
- mode—>指定模式:只读,写入,追加等等。表。一般默认只读。
- encoding—>指定文件编码,通常使用"utf-8"/""GBK
- buffering—>若设置为0,不会有寄存;设为1,访问文件时会寄存行;设为大于1的数,表明是寄存区的缓冲大小;设为负数,则寄存区的缓存区大小为系统默认。
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
rb | 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。 |
r+ | 打开一个文件用于读写。文件指针将会放在文件的开头。 |
rb+ | 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。 |
w | 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
wb | 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
w+ | 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
wb+ | 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
ab | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
a+ | 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。 |
ab+ | 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。 |
文件对象的属性:
属性 | 描述 |
---|---|
f.name | 返回文件的名称 |
f.mode | 返回打开文件的访问模式 |
f.closed | 如果文件已关闭,返回true,否则flase |
关闭:
f.close()
节省计算机资源和提供性能,使用完文件之后,关闭它。
7.4文件的读写
读:
- f.read([size])
- 从文件指针处读取
- 传递size,指定读取的字节数
- readline()
- reanlines()
定位读取
f.tell()
- 获取文件的当前位置。
f.seek()
- seek(offet,[,from])
- offest,要移动的字节数
- from,指定偏移的参考位置
- 0—>从头开始偏移
- 1—>从当前位置开始偏移
- 2—>从末尾位置开始偏移
(八)模块(module)
为了编写方便维护代码,可以把不同功能的代码分组,保存在不同的文件。
在Python中,一个.py文件就可以称之为一个模块
即:
- 包含相应功能的函数以及变量,py则以".py"为后缀名;
- 模块可以为其他的程序引用,以使用该模块所对应的函数或者变量。
使用的模块的优点:
- 提高代码的可维护性
- 提高代码的复用性
- 可以导入很多功能的模块
- 标准库模块
- 第三方模块
- 自定义模块
- 避免变量名重复(作用域)
Python中导入模块的常用方式:
import 模块名称
import 模块名称 as 新名称
from 模块名称 import 函数名
区别:
- import 模块名称 和 import 模块名称 as 新名称
- 会导入整个模块
- 如果我们需要使用某个函数,必须以"模块名称.函数名()"的形式来调用相应的函数。(这种方法可以更有利于代码的可读性(优先推荐使用的方法))
- import 模块名称 as 新名称 ,重新命名导入的模块,通常使模块名称简介,方便使用。
- from 模块名称 import 函数名
- 只导入了某一函数,而不是一整个模块
- 可以直接函数名称去调用函数,而无需再函数名称前加模块信息
- 如果我们的程序语句很多,不建议采用此种方法。原因调用很多模块后,可能造成函数名重名引发错误。
import …
import… as …
from…import函数
注意:
import语句的对应模块顺序(PEP)(程序的最上方)
- Python标准库模块
- 第三方模块
- 自定义模块
8.1自定义模块
8.2os模块
os模块是Python标准库中用于访问操作系统功能的模块。
使用OS模块提供的接口,能够实现跨平台访问。
最常见操作:
- 目录操作
- 判断
8.3系统操作
- os.sep:用于查看系统路径的分隔符;
- Windows—>"\"
- ubuntu—>"/"
- os.name:显示我们正在使用的平台
- windows—>‘nt’
- Linux/Unix—>‘posix’
- os.getenv()—>读取环境变量(environment)
- os.getcwd()—>获取当前路径
8.4目录操作—>增删改查
- os.listdir():返回指定目录下的所有文件和目录名
import os
print(os.listdir()) #未指定路径,当前路径下
['.idea', '1.py', '3.py', '4.py', '5.py', '6.py', '7.py', 'data', 'venv']
import os
dirs = "C:/Users/asus/PycharmProjects" #指定路径上查找
print(os.listdir(dirs))
['untitled2']
-
目录的创建
- os.mkdir(path):创建目录,但仅创建一级目录
- os.makedirs(path):创建目录,创建多级目录
import os os.mkdir("os_test") os.makedirs("main_file/sub_file")
-
目录/文件删除
- os.rmdir(path):删除空目录(一级)
- os.removeddirs(path):删除空目录(多级)
- os.remove(path):删除该文件,必须是文件
import os
os.rmdir("os_test")
os.remove("main_file/新建新文档.txt")
-
更改路径
-
chdir(path):将当前工作目录更改到指定的工作目录
import os print(os.getcwd()) C:\Users\asus\PycharmProjects\untitled2 os.chdir("..")#俩个点表示上一级目录 print(os.getcwd()) C:\Users\asus\PycharmProjects
-
os.rename(old name,new name)
os.rename("666.txt","666.md")
-
8.5判断文件
- os.path.exists(path):判断文件或者目录是否存在,存在,True,反之,False
- os.path.isfile(path):判断是否为文件,是 True 反之,Flase
- os.path.isdir(path):判断是否为目录,是 True 反之,Flase
import os
print(os.path.isfile("666.md"))
print(os.path.isdir("1.py"))
拓展:
-
os.path.dirname(path):返回文件路径;
-
os.path.basename():返回文件名称;
-
os.path.getsize(name):返回文件大小;
-
os.abspath(name):返回文件的绝对路径
-
os.path.join(path,name):连接目录与文件名或者目录
-
os.path.split(path):将path的目录和文件名称分割开,并返回元组
-
查看文件的时间:
- os.path.getmtime(path):—>modify 返回文件或者目录最后的修改时间,结果为秒数
- os.path.getatime(path):返回文件或者目录的最后访问时间,结果为秒数
- os.path.getctime(path):返回文件或者目录的创建时间,结果为秒数
-
获取文件和目录
- os.walk(path):
import os paths = os.walk("..") for i in paths: print(i)
(九)错误和异常
9.1错误
- 语法错误(syntax error)
- 逻辑错误(logic error)
- 执行期间错误(runtime error)
python的语法分析器完成,检测到错误所在文件和行号。以向上的箭头标记错误位置,最后显示错误类型。
当程序检测到一个错误,解释器就无法继续执行下去,抛出异常,终止程序。
9.2异常
系统根据不同的错误,抛出不同的异常。
常见异常:
异常 | 描述 |
---|---|
NameError | 尝试访问一个没有申明的变量 |
ZeroDivisionError | 除数为 0 |
SyntaxError | 语法错误 |
IndexError | 索引超出序列范围 |
KeyError | 请求一个不存在的字典关键字 |
FileNotFoundError | 文件未发现错误(比如你要读的文件不存在) |
AttributeError | 尝试访问未知的对象属性 |
ModuleNotFoundError | 模块未发现 |
IndentationError | 缩进 |
异常处理:
程序一旦发生错误,程序就无法继续运行。
为了使程序健壮,可做相关异常处理。
try…except…
- try子句
- try … except 必须放在可能发生异常的程序段周围,而try_statements则是可能发生异常的程序段。
- except子句
- 用来捕捉指定的异常,一旦捕捉到,就执行与之对应的except_statements,即用来处理异常的程序语句。
- 如果要针对不同的异常做不同的处理,可以使用多个except子句,其中,exceptionType是欲捕捉的异常类型,省略不写,表示为预设类型:BaseException,所有异常都继承自该类别。
- [as identifier]可以将捕捉到的异常指向一个变量,然后,通过该变量获得异常相关的信息。
- 不带任何异常类型使用except,将捕获所有发生的异常。不推荐这么使用,因为我们不能通过该程序识别出具体的异常信息。
- else子句
- 当try_statements没有异常发生时,会跳过except子句,执行else_statements。
- 该子句为可选语句,可以指定或者省略。
- finally子句
- 当要离开try … except 时(无论异常是否发生),就会执行finally_statements,可以使清除错误或者收尾的语句。可给可忽略。
x = eval(input("请输入被除数"))
y = eval(input("请输入除数"))
z = x/y
try:
x = eval(input("请输入被除数"))
y = eval(input("请输入除数"))
z = x / y
#except ZeroDivisionError:
# print("除数不能为0")
#except NameError:
# print("请检查变量是否赋值")
except (ZeroDivisionError,NamteError,TypeError) as e:
print(e.args)
else:
print("未捕捉到异常,x/y=",z)
finally:
print("离开try...except 模块")
9.3raise(触发异常)
除了系统抛出异常,我们可以用raise语句自己触发异常。
格式:
raise [Exception [,args [,traceback]]]
- Exception:异常类型
- args:我们自己提供的异常参数
- traceback:可选,如果存在,跟踪异常对象
try:
raise NameError("Sorry,Error occurs")
Traceback(most recent call last):
File"<stdin>",line 1, in <module>
NameError:Sorry,Error occurs
9.4assert(断言)
assert condition
逻辑上相当于:
if not condition:
raise AssertionError()
为断言添加一个异常参数:
assert expression [,args]
arguments