day9:文件相关 *** 作&文件扩展模式&文件相关函数

day9:文件相关 *** 作&文件扩展模式&文件相关函数,第1张

概述文件的 *** 作 # 文件的写入 # 1.打开文件 fp = open("ceshi1.txt",mode="w",encoding="utf-8&quot

文件的 *** 作

# 文件的写入# 1.打开文件fp = open("ceshi1.txt",mode=wutf-8")  把冰箱门打开 2.写入内容fp.write(把大象塞进去 把大象放进去 3.关闭文件fp.close()  把冰箱门关上
 文件的读取r1.打开冰箱门 2.读取内容res = fp.read()  把大象拿出来print(res) 把冰箱门关上

 字节流

字节---->bytes---->是用来传输或者存储的数据格式

例如:b'1234' b"abcd",范围只能是ascii编码

形如b"我爱你",这种b后面带中文的,是不可以的

如果是中文使用encode 和 decode 来进行转换;

将字符串和字节流(Bytes流)类型进行转换 (参数写成转化的字符编码格式)

encode() 编码 将字符串转化为字节流(Bytes流)

decode() 解码 将Bytes流转化为字符串

strvar = 我爱你" encode 编码 -> 变成二进制字节流res = strvar.encode(")print(res,type(res))  b'\xe6\x88\x91\xe7\x88\xb1\xe4\xbd\xa0' <class 'bytes'> decode 解码 =>二进制字节流恢复成原来的字符串res2 = res.decode(print(res2,type(res2))  我爱你 <class 'str'>

存储二进制字节流

 存储二进制字节流"""不需要指定enCoding编码集,否则报错"""fp = open(ceshi2.txtwb)fp.write(strvar2)fp.close()

读取二进制字节流

 读取二进制字节流fp = open(rb)res = fp.read()fp.close()print(res)  b'\xe6\x88\x91\xe7\x88\xb1\xe4\xbd\xa0' 通过decode反解出字符串strvar = res.decode()print(strvar)  我爱你

复制图片也是要用到rb和wb的

 复制图片图片,音频,视频""" 1.读取原图片所有的内容fp = open(集合.png fp.read()fp.close()  2.把读取的内容存储到另外一个文件 fp = open("集合2.png",mode="wb") 指定绝对路径(完整路径)fp = open(rE:\python31\day8\集合3.png)fp.write(res)fp.close()

文件的扩展模式

1.r+ 先读后写

 1.r+ 先读后写fp = open(ceshi3.txtr+)  先读res = fp.read() 后写fp.write(1234) 再读fp.seek(0)  调整光标位置在开头res =(res)fp.close()

2.r+ 先写后读

 2.r+ 先写后读)fp.seek(0,2)  调整光标位置在末尾fp.write(123)fp.seek(0)res =(res)fp.close()

3.w+ 可读可写

 3.w+ 可读可写fp = open(ceshi4.txtw+)fp.write(abc(res)fp.close()

4.a+ 可读可写(追加写)

 4.a+ 可读可写fp = open(ceshi5.txta+ a模式在写入内容时,会强制把光标移动到最后fp.seek(1)  虽然移到了索引为1的位置,但是在a+模式下,会强制把光标移到最后fp.write()fp.close()

r+和a+的区别:a+是追加写,而r+只会在光标位置后写,不会像a+一样强制将光标拽到最后

文件的三个函数

'''原文件内容:窗前明月光,疑是地上霜''')res = fp.read(3 床前明fp.seek(6)  注意:seek(6)是从开始位置移动6个字节,并非6个字符!!print(fp.read(1)) 计算文件指针左侧所有的字节数res = fp.tell()  tell计算的也是字节数,并非字符数(res)fp.close()

要注意:seek(6)是从开始位置移动6个字节,并非6个字符

    tell()统计的也是指针左侧所有的字节数,并非字符数

    seek在移动中文的时候,有可能报错。比如一个汉字占3个字节,而你却seek(2)

 

with语法的使用

 with语法的使用 (close *** 作with语法可以自动实现)with open() as fp:    res = fp.read() 赋予绝对路径with open(rE:\python31\day8\集合4.png) as fp:    fp.write(res) 继续优化 合并withwith open(") as fp1,open(rE:\python31\day8\集合5.png) as fp2:    res = fp1.read()    fp2.write(res)

close:文件关闭的意义

 close 文件关闭的意义刷新缓冲区 flush    # 当文件关闭的时候自动刷新缓冲区    # 当整个程序运行结束的时候自动刷新缓冲区    # 当缓冲区写满了  会自动刷新缓冲区    # 手动刷新缓冲区ceshi6.txtzzz 手动把缓冲区里面的内容写入文件当中fp.flush() 制造一个死循环,让其无法执行close函数while True:    passfp.close()

文件的相关函数

1.readable和writable

fp = open(readable()  功能: 判断文件对象是否可读res = fp.readable()writable()  功能: 判断文件对象是否可写res = fp.writable()print(res)

2.readline 读取一行文件内容

原文件内容:床前明月光疑是地上霜举头望明月低头思故乡"""参数 > 当前行字符总个数 => 以当前行读取参数 < 当前行字符总个数 => 以参数的大小来读取字符的个数默认readline 读取一行with open(ceshi7.txt) as fp:    res = fp.readline(3000)    (res)     文件对象fp也是一个可迭代对象    在遍历文件对象的时候,默认一次拿一行'''    for i in fp:        print(i)

3.用readline读取文件的所有内容

 readline读取所有内容with open() as fp:         先读取一行    res = fp.readline()     判断是不是空     res:        (res)        res = fp.readline()

4.readlines()  功能:将文件中的内容按照换行读取到列表当中

readlines()    功能:将文件中的内容按照换行读取到列表当中lst_new = []with open() as fp:        lst = fp.readlines()    print(lst)  ['\t窗前明月光\n','疑是鞋两双\t\t\n','\t\t举头王明月\n','\t低头看裤裆']     lst:                lst_new.append(i.strip())print(lst_new)      ['窗前明月光','疑是鞋两双','举头王明月','低头看裤裆']

5.writelines() 功能:将内容是字符串的可迭代性数据写入文件中 

writelines()   功能:将内容是字符串的可迭代性数据写入文件中 参数:内容为字符串类型的可迭代数据可迭代型数据(容器类型数据,range对象,迭代器)lst = [春眠不觉晓\n处处蚊子咬\n夜来大狗熊\n一个也跑不了\n]lst = [1,2,3,4]   error 列表中的元素必须是字符串类型,而非数字类型with open(ceshi8.txt) as fp:    fp.writelines(lst)

6.truncate() 功能: 把要截取的字符串提取出来,然后清空内容将提取的字符串重新写入文件中 (字节)

truncate()     功能: 把要截取的字符串提取出来,然后清空内容将提取的字符串重新写入文件中 (字节)with open() as fp:    fp.truncate(9)  9代表9个字节,而不是9个字符

 

总结

以上是内存溢出为你收集整理的day9:文件相关 *** 作&文件扩展模式&文件相关函数全部内容,希望文章能够帮你解决day9:文件相关 *** 作&文件扩展模式&文件相关函数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1190139.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存