【8】python文件的读写方法

时间:2024-04-16 13:20:43

 

 

 

(1)、读文件的步骤:

(1)打开文件
  open(path,flag,encoding,[errors])
  path:打开路径
  flag:打开方式 r(只读) rb(二进制格式) r+(可以读写)
        w(只写,存在覆盖,不存在创建) wb(写入二进制) w+(用于读写)
  a(文件存在,追加) a+()
  encoding:编码方式
  errors:错误处理

(2)读取文件


(3)关闭文件

 

(2)读取文件的几种方法

# 第二步:读取文件内容 的四个方法

#1:方法1-读取文件的全部内容[只适合读取小的文件,不然费内存]
str1=f.read()
print(str1)

# 2 方法2-读取指定字符数
str2=f.read(10)
print(str2)
str3=f.read(2)
print(str3)


\'\'\'
输出:
def proces
sF
总结:文件不关闭的情况下,读完一次,指针在最后边,继续读2个字符信息。
\'\'\'


# 3 方法3-每次读取一行数据,包括‘\n’
# str4=f.readline()
str4=f.readline(10)     #表示读取一行的10个字符
print(str4)


# 4 方法4-读取方式4  读取所有行并返回列表
list7=f.readlines()
list7=f.readlines(22)     #每行读取这么多
print(list7)

(3)关闭文件

# 第三步:关闭文件
f.close()

 

【总结】:完整的两种读文件方式

方法1:

try:
    f1=open(path,\'r\',encoding=\'utf8\',errors=\'ignore\')
    print(f1.read())
except:
    print("文件读取出错!")
finally:
    if f1:
        f1.close()

 

方法2:带with的自动关闭文件的方式

# 方法2  with 自动关闭文件

path=r\'E:\[AAA]全栈学习python\day2\file1.txt\'
try:
    with open(path) as file_obj:
        content=file_obj.read()
        print(content)
except:
    print("读取失败!")

 

 

一、原生态三步法写入文件

# 文件写入

# 第一步:打开文件
path=r"E:\[AAA]全栈学习python\day2\file2.txt"
f=open(path,\'w\')

# 第二步:写文件
#1 这里其实只是先写入了缓冲区,但是还没得奥文件中去,需要刷新
f.write("jiajia is a beautiful girl333 !")

# 2 刷新缓冲区,就是立即写入文件,不写刷新就是关闭才能写入文件
f.flush()

# 第三步:关闭文件
f.close()

说明: flush()是及时就写入到文件中去,没有这个flush的话 只会等到文件关闭的时候才会被写入到文件。

【注意】:还有就是在写入时候遇到\'\n\' 或者是缓冲区满了也会自动刷新

 

 

案例2:用带with自动关闭文件且追加的方式写入

# 案例2:用带with自动关闭文件且追加的方式写入
with open(path,\'a\') as file_obj:
    file_obj.write("康忙北鼻是一个帅哥!")

# file_obj.flush() #这种方式是不需要刷新与关闭操作的。

案例3

# 1 普通写入一个文件信息
path=r\'E:\[AAA]全栈学习python\day3\file1.txt\'
with open(path,\'w\') as f1:
    str="I love programming"
    str2="I also like write articles"
    f1.write(str)
    f1.write(str2)

\'\'\'
输出:
发现两个写入的文件信息都在一行显示了。
I love programmingI also like write articles
解决办法:
在每个str 中加上换行符即可!
\'\'\'

# 2每添加一段信息 ,带换行信息写入如何做呢!

path2=r\'E:\[AAA]全栈学习python\day3\file2.txt\'
with open(path,\'w\') as f1:
    str="I love programming\n"
    str2="I also like write articles \n"
    f1.write(str)
    f1.write(str2)

\'\'\'
输出
I love programming
I also like write articles 
\'\'\'


# 3 附加到文件file2
with open(path2,\'a\') as file_obj:
    file_obj.write("i am the first one!\n")
    file_obj.write("I AM THE SECOND ONE!\n")
    
\'\'\'
输出:
i am the first one!
I AM THE SECOND ONE!
\'\'\'

 

 

二、二进制文件的写入

案例1

# 存入和读取二进制文件信息
path = r\'E:\[AAA]全栈学习python\day3\file3.txt\'
with open(path,\'wb\') as f1:
    str_bytes=\'I am jiyongjia !\'.encode(\'utf-8\')
    f1.write(str_bytes)

with open(path,\'rb\') as f2:
    str2=f2.read()
    print(str2)
    print(type(str2))

\'\'\'
输出、
b\'I am jiyongjia !\'
<class \'bytes\'>
我们发现读取的并不是字符串,所以并不好处理
\'\'\'

总结:我们发现读取的并不是字符串,所以并不好处理

 

案例2:处理以上案例,让读取出的信息是一个str 方便处理

# 读取
with open(path,\'rb\') as f2:
    str2=f2.read()
    print(str2.decode(\'utf-8\'))
    print(type(str2.decode(\'utf-8\')))

\'\'\'
输出:
I am jiyongjia !
<class \'str\'>
这里就是提取的字符串了; 
\'\'\'

所以,有时候我们需要把读取到的数据进行解码才行!

 

关于二进制的读写总结

# 总结:

如果是按照二进制打开文件的,要写入或者读取一定要编码 解码。
# 对于二进制的读与写,要进行对应结构的编码与解码,编码和解码用相同的方式才行。中文也可以解析出。
# 写的时候:str_bytes=\'I am jiyongjia嘉 !\'.encode(\'utf-8\')
# 读的时候:str2=f2.read().decode(\'utf-8\')

\'\'\'
如果不进行decode解码输出的话会是:b\'I am jiyongjia\xe5\x98\x89 !\' 它是一个 <class \'bytes\'> 非字符串,不好操作、
如果使用了decode 解码再输出的话,输出结果是一个I am jiyongjia嘉 ! 它是一个 <class \'str\'>
\'\'\'

方法一:使用pickle库 来进行读写

import pickle     #引入数据持久性模板



# 1--使用 pickle 方式写入进去。
mylist = [1,2,3,4,5,6,"jiajia","我是雷锋"]
# 把这个list写入文件4
path = r\'E:\[AAA]全栈学习python\day3\file4.txt\'
f= open(path,\'wb\')    #打开
pickle.dump(mylist,f)
f.close()             #关闭


# 读取出来、
f2= open(path,\'rb\')    #打开
templist=pickle.load(f2)
print(templist)
f2.close()             #关闭


\'\'\'
输出:
[1, 2, 3, 4, 5, 6, \'jiajia\', \'我是雷锋\']
\'\'\'

 

方法二:使用json库 来进行读写

说明:

json 文件 非常有用,因为我们往往需要在关闭程序前把程序所处理得到的数据进行保存,在下一次打开程序的时候再加载这些数据,这就要用到json。而且 json 数据是一种通用格式,通过json 就可以把数据打包分享给其他语言的程序员使用了,便于跨平台操作。

# 说明:
# json 文件 非常有用,因为我们往往需要在关闭程序前把程序所处理得到的数据进行保存,
# 在下一次打开程序的时候再加载这些数据,这就要用到json。而且 json 数据是一种通用格式,
# 通过json 就可以把数据打包分享给其他语言的程序员使用了,便于跨平台操作。

import json

# 1 把列表存入到json 文件  即json.dump
list1=[1,12,3,4,5,6,"嘉嘉","jiajai"]
dict1={"1":"puyhon学习",\'2\':"Java学习"}

path= r\'E:\[AAA]全栈学习python\day3\jsonfile1.json\'
with open(path,\'w\') as json_file:
    json.dump(list1, json_file)
   

# 2 把json文件中的内容取出  即json.load
path= r\'E:\[AAA]全栈学习python\day3\jsonfile1.json\'
with open(path) as f2:
    file=json.load(f2)
    print("welcome back! 提取内容是:",file)