写数据(write)
格式
对象 = open("文件",w)
对象.write("写入数据")
对象.close
案例:以写的方式打开文件,写入数据
f = open('test.txt', 'w')
f.write('hello world, i am here!')
f.close()
继续写入数据
f = open('test.txt', 'w')
f.write('I love you')
f.close()
总结:如果文件不存在那么创建,如果存在那么就先清空,然后写入数据
读数据(read)
格式
对象 = open("文件",r)
变量 = 对象.read()
print(变量)
案例:读取文件(test.txt)
f = open('test.txt', 'r')
content = f.read()
print(content)
总结:如果用open打开文件时,如果使用的"r",那么可以省略,即只写 open('test.txt') ,如果没有文件,打开报错,存在该文件才能操作 如果文件中存在中文显示,会出现乱码需要添加encoding='utf-8' open(‘test.txt’,”r”, encoding='utf-8')
案例:读取指定长度的数据(单位是字节)
f = open('test.txt', 'r')
content = f.read(5) # 最多读取5个数据
print(content)
使用read(num)可以从文件中读取数据,num表示要从文件中读取的数据的长度(单位是字节),如果 没有传入num,那么就表示读取文件中所有的数据
读数据(readlines)
就像read没有参数时一样,readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返 回的是一个列表,其中每一行的数据为一个元素
格式
对象 = open("文件",r)
变量 = 对象.readlines()
print(变量)
案例:读取文件(test.txt)
f = open('test.txt', 'r')
content = f.readlines()
print(content)
print(type(content))
读数据(readline)
readline可以按照行的方式把整个文件中的内容进行一行一行的读取
格式
对象 = open("文件",r)
变量 = 对象.readline()
print(变量)
可写(a)
格式
对象 = open("",a)
对象.write("写入数据")
对象.close
案例,在文件中写入数据
f = open("test.txt",a)
f.write("新的数据")
对象.close
总结:(可写)形式打开文件,如果文件不存在则创建并从头添加写入的内容,存在则原有数据后追加数据
二进制文件的读写
读数据(rb)
格式1
对象 = open("二进制文件",rb)
变量= 对象.read()
print(变量)
格式2
with open("二进制文件","rb") as 对象:
变量 = 对象.read()
print(变量)
案例:使用尽可能多的方式实现读取图片
f = open('33.jpg', 'rb')
content = f.read()
print(content)
with open("33.jpg","rb") as rf:
res = rf.read()
print(res)
格式2中不需要手动关闭文件,所以经常被使用
总结:如果没有文件,打开报错,存在该文件才能操作
写数据(wb)
格式
with open("二进制文件","wb") as 对象:
变量 = 对象.write()
print(变量)
案例:备份图片
with open("1.jpg","rb") as rf:
res = rf.read()
with open("textjpg.jpg", "wb") as wf:
res = wf.write(res)
print(res)
关闭文件
格式
close( )
文件重命名
os模块中的rename()可以完成对文件的重命名操作
格式
import os
os.rename("需要修改的文件名","新文件名")
案例:
import os
os.rename("test.txt","new.txt")
删除文件
os模块中的remove()可以完成对文件的重命名操作
格式
import os
os.remove("文件名")
案例:
import os
os.rename("new.txt")
创建文件夹
os模块中的mkdir()可以完成对文件的重命名操作
获取当前目录
os模块中的getcwd()可以获取当前目录
异常
什么是异常?
异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。 一般情况下,在Python无法正常处理程序时就会发生一个异常。 异常是Python对象,表示一个错误。 当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行。
演示异常
f = open("11111.txt","r") #FileNotFoundError ----文件找不异常
i="1"
if i>0:
print("i大于0") #TypeError ----数据类型异常
name="jack"
print(name[7]) #IndexError: string index out of range ----下标索引超出序列范围
info={"name":"jack","age":12}
print(info["name123"]) #KeyError------访问字典里不存在的键
name="jack"
print(name.index("g")) #ValueError: substring not found---------传入无效的值,即使值的类型是正确的
f = 8/0
print(f) #ZeroDivisionError: division by zero--------- 除法运算中除数0 或者 取模运算中模数为0
异常处理
作用:捕捉异常可以使用try/except语句。 try/except语句用来检测try语句块中的错误,从而让except语句捕获异常信息并处理。 如果你不想在异常发生时结束你的程序,只需在try里捕获它
语法
try:
<语句>#运行别的代码
except :
<语句>#如果在try部份引发了'name'异常
else:
<语句>#如果没有异常发生
代码
try:
open("qwe.txt","r")
print("123")
except FileNotFoundError:
print("异常处理")
else:
print("没有异常")
try:
open("qwe.txt","r")
print("123")
except FileNotFoundError as result:
print("异常处理",result)
else:
print("没有异常")
使用except而不带任何异常类型
语法
try:
正常的操作
except :
发生异常,执行这块代码
else:
如果没有异常执行这块代码
代码
try:
open("qwe.txt","r")
print("123")
except :
print("异常处理")
else:
print("没有异常")
注意:以上方式try-except语句捕获所有发生的异常。但这不是一个很好的方式,我们不能通过该程序识别 出具体的异常信息。因为它捕获所有的异常。
使用except而带多种异常类型
语法
try:
异常的操作
except(Exception1[, Exception2[,...ExceptionN]]]):
发生以上多个异常中的一个,执行这块代码
......................
else:
如果没有异常执行这块代码
代码
list = [1,2,3,4]
try:
open("qwe.txt", "r")
list[7]
except (NameError,FileNotFoundError) as rese:
print("出现异常")
else:
print("没有异常")
try-finally 语句
语法
try:
<语句>
finally:
<语句>#退出try时总会执行
案例
try:
fh = open("test.txt", "r")
fh.readlines()
fh.close()
finally:
print("Error: 没有找到文件或读取文件失败")
注意:当在try块中抛出一个异常,立即执行finally块代码。 finally块中的所有语句执行后,异常被再次触发,并执行except块代码。 参数的内容不同于异常
异常的传递
代码
def func1():
print("---func1--1---")
print(num)
print("---func1--2---")
# def func2():
# print("--func2--1---")
# func1()
# print("--func2--2---")
def func3():
try:
print("---func3--1---")
func1()
print("--func3--2----")
except Exception as result:
print(result)
print("--func3---3---")
func3()
#func2()
:触发异常
可以使用raise语句自己触发异常
用户自定义异常
定义:通过创建一个新的异常类,程序可以命名它们自己的异常。异常应该是典型的继承自Exception类,通过直接 或间接的方式
代码:长度不低于3为
class ShortInputException(Exception):
def __init__(self, length, atleast):
self.length = length
self.atleast = atleast
def main():
try:
s = input('请输入 --> ')
if len(s) < 3:
# raise引发一个你定义的异常
raise ShortInputException(len(s), 3)
except ShortInputException as result:#x这个变量被绑定到了错误的实例
print('ShortInputException: 输入的长度是 %d,长度至少应是 %d'%(result.length,result.atleast))
else:
print('没有异常发生')
main()