一、文件操作
文件都有后缀,不同的后缀表示文件存储的方式不同。
在Python中文件的操作:
1、打开文件
open(文件路径,打开模式=‘r’)
open函数有一个返回值,其职值是被打开文件句柄对象:(对文件的句柄对象进行操作,就相当于对文件进行操作)
文件路径:文件在电脑中对应的地址
1.直接写全路径(不推荐使用) /Users/yuting/Desktop/JAVA/授课/Python1803/文件操作/bb.txt
2.一般将涉及到的文件放到工程中:
a. 文件和代码对应的.py文件在一个目录下面:路径直接写文件名
b. 在工程文件夹下,但是不直接和代码文件在一个目录里面: ./放文件的文件夹名字/文件名
打开的模式: 'r'->文本读(以读的形式打开,只能获取内容,不能修改文件内容)
'w'->文本写 (以写的形式打开,只能修改文件内容,不能获取文件内容)
'a'->文本写
'br'->二进制读
'bw'->二进制写
'ba'->二进制写
2、打开文本文件
a、打开文件
f = open('./files/aaa.txt', 'r', encoding='utf-8')
f:f为被打开文件对应的句柄
utf-8: 一种文本编码方式,就是使用1-6个字节对Unicode进行编码;
utf-8就可以编码所有国家的语言对应的字符的文本
b.读操作
注意:对同一个文件句柄对象进行读操作,每读一次内容,下次再读的时候,从上次读的结束的位置往下读
read(): 获取文件中所有的内容,并且返回
文本文件读取的结果是字符串
reslut = f.read()
print(reslut, type(reslut))
read(n): n->指定读取的文本长度(-1:读全部内容, n大于长度:读取所有内容)
readline(): 每次读一行内容
readlines(): 让文件中所有的内容读出来(将每一行的内容作为列表的元素返回的)
二、修改读取的位置
每次读取文件完成后,下次读取文件,是接着上一次读取的位置进行读取,通过设置偏移量可以修改文件读取的开始位置。
seek(偏移量):偏移量是字节数(一个字母是一个字节,一个中文汉字是两个字节)。
设置读写位置为文件的开始: 后边进行读操作的时候,就是从文件开始的位置往后读
三、文件的写操作
写操作(修改文件内容):
1.打开文件
2.写操作
3.关闭
f = open('test.txt', 'a', encoding='utf-8')
write(写的内容): 文本文件中写的内容是字符串
注意: 'w'-> 写的时候会覆盖原文件的内容 'a' -> 在原来的内容的后面去追加内容
f.write('\n举头望明月')
f.seek(0) # 后面写的时候,会以覆盖前面写的内容的形式去写
f.writelines(['aaaa', 'bbbb', 'ccccc','hhhhhhh'])
f.close()
四、文本文件读写
1、文件操作的步骤:
1.打开文件
2.操作
3.关闭
2、python中打开文件
open函数:
open(文件路径,打开方式,编码方式)
文件路径:绝对地址(/Users/yuting/aaa.txt)、相对地址(./相对路径)-->相对于当前工程目录
打开方式:
'r' ---> 读(默认)
'w' ---> 写(1.覆盖原文件内容)
'a' ---> 写(在原文件内容后追加)
a、读操作
注意: 如果文件的路径写错了会报:FileNotFoundError
f = open('test.txt', 'r', encoding='utf-8')
print(f.read())
f.close()
b、写操作
注意:'w'、'a'打开文件,如果这个文件不存在,会创建一个新的文件
f1 = open('test1.txt', 'w', encoding='utf-8')
f1.write('1234567')
f1.close()
f1 = open('test2.txt', 'a', encoding='utf-8')
f1.write('1234567')
f1.close()
在python中可以使用以下结构来进行文件操作过程:
with open() as 文件变量:
在文件打开后关闭前执行的代码段
with open('test.txt', 'r', encoding='utf-8') as f:
print(f.read())
五、二进制文件
二进制文件的读
bytes类: python中的二进制数据对应的类型是bytes --> data
with open('./files/chuangxu.png', 'br') as f:
data = f.read()
print('===:',type(data))
print(reslut)
二进制文件的写
'ba':无追加效果
with open('./files/new.png', 'bw') as f:
data需要是bytes类型的数据
f.write(data)
六、json文件
json文件: 就是后缀是.json的文件,用来存储文本数据(以特殊的语法结构来存储文本信息)
最外层要么是字典结构,要么是数组(列表)结构
里面的数据:字符串、数字、二进制、字典、数组(列表)
{} -> 字典结构
{
"name":"aa",
"age":18,
"score":[100, 90, 80]
}
[] -> 数组(列表)结构
[
100,
"name",
"person":{"name":"张三", "age":30}
]
"" -> 字符串
"
name ,sfjk,{ksjjdk},kksjkjk
"
json文件的读写:python中使用python内置模块json来对json数据进行操作
import json
读取json文件中的内容:
json.load(f):读的结果只有两种情况:要么是字典、要么是列表
with open('./files/myjson.json','r', encoding='utf-8') as f:
result = json.load(f)
print(type(result))
print(result)
json文件的写操作:
json.dump(写的内容,f): 写的内容只能是字典或者列表
son.dump(写的内容,f): 写的内容只能是字典或者列表
with open('./files/myjson.json', 'w', encoding='utf-8') as f:
tuple1 = (10, 20, 'abc') # 写进去还是列表
json.dump(tuple1, f)
八、异常捕获
格式1
try:
代码块1(需要捕获异常的代码块)
except:
代码块2(出现异常后执行的)
执行过程:先执行代码块1,如果执行代码块1的时候出现异常,就执行代码块2;
如果代码块1不出现异常,就执行try结构外的其他语句
格式2:
try:
代码块1
except 错误类型列表:
代码块2
出现指定错误类型的异常,才捕获
学生信息:
写一个添加学生的功能,将添加的学生信息持久化
1,添加学生
2、查看学生
import json
try:
with open('myjson.json', 'r', encoding='utf-8') as f:
dict1=json.load(f)
except json.decoder.JSONDecodeError:
dict1={}
name=input("请输入学生姓名:")
age=int(input("请输入年龄:"))
call=int(input("请输入电话号码:"))
dict={}
dict["name"]=name
dict["age"]=age
dict["call"]=call
dict1[name]=dict
with open('myjson.json','w',encoding='utf-8') as f:
json.dump(dict1,f)
print(dict1)
网友评论