文件操作

文件(保存数据--永久的)
文件都有后缀,不同的后缀表示不同的存储方式
文本文件(存文字信息) ----.txt, .word, .md等
二进制文件:视频文件、音频、图片 ----.mp4, .mov, .avi, .mp3, .png, .jpg, .gif等
可执行文件等 ----.exe, .api, .dmg等

文本文件、二进制文件、json文件(重点)的操作
文件操作(对文件进行读写)

  • 步骤(对所有的文件操作有效):
    1.打开文件
    2.对文件进行读/写操作(读:获取文件内容 写:修改文件内容)
    3.关闭文件
  • python操作文件:
    1.打开文件
    open(文件路径, 打开的模式='r')
    open函数有一个返回值:返回的就是被打开的文件句柄对象
    文件句柄:就是文件的代言人,对文件句柄对象进行的操作,就相当于对文件进行操作
    文件路径:文件在电脑中对应的地址
    1.直接写全路径(不推荐使用) /Users/yuting/Desktop/JAVA/授课/Python1803/文件操作/bb.txt
    2.一般将涉及到的文件放到工程中:
    a. 文件和代码对应的.py文件在一个目录下面:路径直接写文件名
    b. 在工程文件夹下,但是不直接和代码文件在一个目录里面: ./放文件的文件夹名字/文件名
    打开的模式: 'r'->文本读(以读的形式打开,只能获取内容,不能修改文件内容)
    'w'->文本写 (以写的形式打开,只能修改文件内容,不能获取文件内容)
    'a'->文本写
    'br'->二进制读
    'bw'->二进制写
    'ba'->二进制写

1.文本文件
a.打开文件
f:就是被打开的文件对应的文件句柄
utf-8: 一种文本编码方式,就是使用1-6个字节对Unicode进行编码;utf-8就可以编码所有国家的语言对应的字符的文本
gbk: 只支持中文文本编码
f = open('./files/aaa.txt', 'r', encoding='utf-8')
b.读操作
注意:对同一个文件句柄对象进行读操作,每读一次内容,下次再读的时候,从上次读的结束的位置往下读
read(): 获取文件中所有的内容,并且返回
文本文件读取的结果是字符串
reslut = f.read()
print(reslut, type(reslut))
read(n): n->指定读取的文本长度(-1:读全部内容, n大于长度:读取所有内容)
readline(): 每次读一行内容
readlines(): 让文件中所有的内容读出来(将每一行的内容作为列表的元素返回的)
关闭文件
f.close()

f = open('./test.txt', 'r', encoding='utf-8')

  1. 读所有的内容
    print(f.read())
    2.读取指定文件的所有内容(一行一行的读)
    while True:
        result = f.readline()
        if not result:
        break
    if result == ' ':
        break
        if len(result)==0:
        break
    f.close()
修改文件读取的位置

读文件,每次读完,下次再读的时候,是接着上次读完的位置往下进行读操作
避免这个问题的方法: 1.重新打开文件,然后再读
2.设置读写位置
f = open('test.txt', 'r', encoding='utf-8')
读取文件中所有的内容,下次再读就是从文件结束的位置往后读
print(f.read())
seek(偏移量):偏移量是字节数(一个字母是一个字节,一个中文汉字是两个字节)
设置读写位置为文件的开始: 后边进行读操作的时候,就是从文件开始的位置往后读
注意: 偏移量一般设置为0
f.seek(0)
f = open('test.txt', 'a', encoding='utf-8')
write(写的内容): 文本文件中写的内容是字符串
注意: 'w'-> 写的时候会覆盖原文件的内容
         'a' -> 在原来的内容的后面去追加内容
f.write('\n举头望明月')

2.python中打开文件

open函数:
open(文件路径,打开方式,编码方式)
文件路径:绝对地址(/Users/yuting/aaa.txt)、相对地址(./相对路径)-->相对于当前工程目录
打开方式:
'r' ---> 读(默认)
'w' ---> 写(1.覆盖原文件内容)
'a' ---> 写(在原文件内容后追加)
写操作

注意:'w'、'a'打开文件,如果这个文件不存在,会创建一个新的文件
f1 = open('test1.txt', 'w', 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文件的写操作:

son.dump(写的内容,f): 写的内容只能是字典或者列表

with open('./files/myjson.json', 'w', encoding='utf-8') as f:
dict1 = {'aaa': 100, 'score': 99, 'person': {'name':'王海飞', 'age':30}}
 json.dump(dict1, f)

异常捕获

格式1
try:
代码块1(需要捕获异常的代码块)
except:
代码块2(出现异常后执行的)

执行过程:先执行代码块1,如果执行代码块1的时候出现异常,就执行代码块2;
如果代码块1不出现异常,就执行try结构外的其他语句

格式2:
try:
代码块1
except 错误类型列表:
代码块2

出现指定错误类型的异常,才捕获
try:
a = [1, 2, 3]
print(a[10])
# with open('./files/test1.json', 'r', encoding='utf-8') as f:
# pass

except FileNotFoundError:
print('出现文件找不到异常')

except ValueError:
print('值错误异常')

except:
print('其他异常出现')

finally:
print('不管有没有异常都要执行')

print('aaa')

你可能感兴趣的:(文件操作)