文件的操作

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

字节流

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

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

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

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

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

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

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

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

存储二进制字节流

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

读取二进制字节流

# 读取二进制字节流
fp = open("ceshi2.txt",mode="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",mode="rb")
res = fp.read()
fp.close() # 2.把读取的内容存储到另外一个文件
# fp = open("集合2.png",mode="wb")
# 指定绝对路径(完整路径)
fp = open(r"E:\python31\day8\集合3.png",mode="wb")
fp.write(res)
fp.close()

文件的扩展模式

1.r+ 先读后写

# 1.r+ 先读后写
fp = open("ceshi3.txt",mode="r+",encoding="utf-8") # 先读
res = fp.read()
print(res) # 后写
fp.write("1234") # 再读
fp.seek(0) # 调整光标位置在开头
res = fp.read()
print(res)
fp.close()

2.r+ 先写后读

# 2.r+ 先写后读

fp = open("ceshi3.txt",mode="r+",encoding="utf-8")
fp.seek(0,2) # 调整光标位置在末尾
fp.write("123") fp.seek(0)
res = fp.read()
print(res)
fp.close()

3.w+ 可读可写

# 3.w+ 可读可写
fp = open("ceshi4.txt",mode="w+",encoding="utf-8")
fp.write("abc") fp.seek(0)
res = fp.read()
print(res)
fp.close()

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

# 4.a+ 可读可写
fp = open("ceshi5.txt",mode="a+",encoding="utf-8")
fp.write("123") fp.seek(0)
res = fp.read()
print(res) # a模式在写入内容时,会强制把光标移动到最后
fp.seek(1) # 虽然移到了索引为1的位置,但是在a+模式下,会强制把光标移到最后
fp.write("abc") fp.close()

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

文件的三个函数

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

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

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

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

with语法的使用

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

close:文件关闭的意义

# close 文件关闭的意义
"""
刷新缓冲区 flush
# 当文件关闭的时候自动刷新缓冲区
# 当整个程序运行结束的时候自动刷新缓冲区
# 当缓冲区写满了 会自动刷新缓冲区
# 手动刷新缓冲区
"""
fp = open("ceshi6.txt",mode="r+",encoding="utf-8")
fp.write("zzz")
# 手动把缓冲区里面的内容写入文件当中
fp.flush() # 制造一个死循环,让其无法执行close函数
while True:
pass fp.close()

文件的相关函数

1.readable和writable

fp = open("ceshi6.txt",mode="a+",encoding="utf-8")
#readable() 功能: 判断文件对象是否可读
res = fp.readable()
print(res) #writable() 功能: 判断文件对象是否可写
res = fp.writable()
print(res)

2.readline 读取一行文件内容

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

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

# readline读取所有内容
with open("ceshi7.txt",mode="r+",encoding="utf-8") as fp: # 先读取一行
res = fp.readline()
# 判断是不是空
while res:
print(res)
res = fp.readline()

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

#readlines()    功能:将文件中的内容按照换行读取到列表当中
lst_new = []
with open("ceshi7.txt",mode="r+",encoding="utf-8") as fp:
lst = fp.readlines()
print(lst) # ['\t窗前明月光\n', '疑是鞋两双\t\t\n', '\t\t举头王明月\n', '\t低头看裤裆']
for i in 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",mode="w",encoding="utf-8") as fp:
fp.writelines(lst)

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

#truncate()     功能: 把要截取的字符串提取出来,然后清空内容将提取的字符串重新写入文件中 (字节)
with open("ceshi7.txt",mode="r+",encoding="utf-8") as fp:
fp.truncate(9) # 9代表9个字节,而不是9个字符

day9:文件相关操作&文件扩展模式&文件相关函数的更多相关文章

  1. python文件相关操作

    Python文件相关操作 打开文件 打开文件,采用open方法,会将文件的句柄返回,如下: f = open('test_file.txt','r',encoding='utf-8') 在上面的代码中 ...

  2. Git基本命令 -- 基本工作流程 + 文件相关操作

    可以先找一个已经被git管理的项目, 我就使用这个项目吧: https://github.com/solenovex/ID3-Editor 基本工作流程 克隆以后呢, 进入该目录查看一下状态: 然后添 ...

  3. c# 封装的文件夹操作类之复制文件夹

    c#  封装的文件夹操作类之复制文件夹 一.复制文件夹原理: 1.递归遍历文件夹 2.复制文件 二.FolderHelper.cs /// <summary> /// 文件夹操作类 /// ...

  4. IO文件相关操作

    IO编程 IO 即Input/Output  input stream 就是数据从外面(磁盘.网络)流进内存,output stream 就是数据从内存流到外面去. 通常cpu 和 内存的速度远远高于 ...

  5. Nodejs文件相关操作

    欢迎关注我的博客我在马路边 适用人群 本文适用于刚接触Node的小白,毕竟我也是小白,大佬请绕行. Node文件操作 在实际开发中遇到很多有关文件及文件夹的操作,比如创建.删除文件及文件夹,文件拷贝. ...

  6. linux学习笔记一----------文件相关操作

    一.目录结构 二.文件管理操作命令(有关文件夹操作,使用Tab键自动补全文件名(如果多个默认第一个)) 1.ls 查看目录信息:ls -l 查看目录详细信息(等价于ll 某些系统不支持) 2.pwd ...

  7. VC++文件相关操作的函数封装实现

    在开发编译工具中,需要用到文件的相关操作,于是就封装了相关的函数实现: //判断文件是否存在 BOOL FileIsExist(CString strFileName) { CFileFind fin ...

  8. day08文件操作的三步骤,基础的读,基础的写,with...open语法,文件的操作模式,文件的操作编码问题,文件的复制,游标操作

    复习 ''' 类型转换 1.数字类型:int() | bool() | float() 2.str与int:int('10') | int('-10') | int('0') | float('-.5 ...

  9. 【原创】Linux基础之gz文件相关操作

    gz文件不需要解压即可进行相关操作 $ zcat test.log.gz $ zmore test.log.gz $ zless test.log.gz $ zgrep '1.2.3.4' test. ...

  10. UNIX高级环境编程(5)Files And Directories - 文件相关时间,目录文件相关操作

     1 File Times 每个文件会维护三个时间字段,每个字段代表的时间都不同.如下表所示: 字段说明: st_mtim(the modification time)记录了文件内容最后一次被修改的时 ...

随机推荐

  1. renren-fast-vue人人开源前端项目搭建保姆级教程

    1.从gitee上clone项目 git clone https://gitee.com/renrenio/renren-fast-vue.git 2.准备好python环境 需要有Python2以上 ...

  2. 按list大小进行分组

    package cn.tk.netcore.rest;import java.util.ArrayList;import java.util.Arrays;import java.util.List; ...

  3. [Leetcode 98]判断有效的二叉搜索树Validate Binary Search Tree

    题目 https://leetcode.com/problems/validate-binary-search-tree 判断所给二叉树是否是二叉搜索树 二叉搜索树:其值left<root< ...

  4. Matlab %补充---用的多的函数

    Input  promat = 'This is a sentence.' x = input(prompt) %显示prompt中的文本并等待用户输入数值或者表达式后按Return %如果用户什么都 ...

  5. 002基本的Dos命令

    002基本的Dos命令 1.开启Dos控制台的几种方式 几种打开CMD的方式: 直接在菜单中搜索"命令提示符". Win+R,输入cmd.(推荐) 在任意文件夹下面,按住Shift ...

  6. Ubantu12.04安装及离线安装网卡驱动

    一.用软通牒UltarISO写入硬盘映像,制作启动U盘 装机,ubantu安装很简单. 二.安装网卡驱动 1. 下载e1000e:https://downloadcenter.intel.com/De ...

  7. Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'hive.DELETEME1643159643943' doesn't exist

    Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'hive.DELETEME1643159643 ...

  8. 微信网页授权——获取code、access_token、openid,及跨域问题解决

    首先在微信开发文档中有提到微信网页授权的操作步骤: 第一步:用户同意授权,获取code 在确保微信公众账号拥有授权作用域(scope参数)的权限的前提下(服务号获得高级接口后,默认拥有scope参数中 ...

  9. vue 作者在2022-2-7起宣布 vue3 正式作为默认版本

    vue 作者在2022-2-7起宣布 vue3 正式作为默认版本 vue 作者尤雨溪在知乎上发布一篇文章,宣布 Vue3 将在 2022 年 2 月 7 日 成为新的默认版本! 并且还在文章中做出了一 ...

  10. MySQL高性能索引策略和查询性能优化

    前缀索引和索引选择性 有时候需要索引很长的字符,这会让索引变得大且慢.一个策略是模拟哈希索引. 通常可以索引开始的部分字符,这样可以大大解约索引空间,提高索引效率.但这样会降低索引的选择性. 索引的选 ...