python文件的打开、读取、关闭、写入与二进制文件的读写操作

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Python全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Python知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注Python)
img

正文

123456

abcdef

01010101

再在原py文件中写入以下代码:

python 操作数据都是要通过操作这个数据创建的变量才可以实施

file_name = ‘demo.txt’ # 绝对路径

file_obj = open(file_name) # 打开的文件对象

print(file_obj)

如果不懂路径相关的,open()函数因为找不到文件而报错,也可以直接把file_name变量名定义成 "路径+demo.txt"的格式。这样无论demo.txt文件放在哪里都是可以找到的。

如图,open(file_name)成功创建出了一个对象。

在这里插入图片描述

可以将文件分为2种类型,

  • 一种是纯文本文件(使用utf-8编码编写的文件)。

  • 一种是二进制文件(图片 mp3 视频…)

open()打开文件时,默认是以文本文件的形式打开的,open()默认的编码为None,所以处理文本文件时要指定编码。这一环节在下边的读取部分中再体现。


1.2 with open(xxx) as xx: 语句


也可以用with open(xxx) as xx: 语句来代替直接进行对open()函数的调用。

file_name = ‘demo.txt’

try:

with open(file_name, encoding=‘utf-8’) as f: # 对于我们打开的这个文件对象取名为f

file_obj = open(file_name) # 打开的文件对象

print(file_obj)

except FileNotFoundError:

print(‘文件名没有找到’)


2. 文件的读取

===============================================================================

2.1 read()函数


通过read()函数读取文件内容时会将文件中所有的内容全部读取出来。。

file_name = ‘demo.txt’

file_obj = open(file_name) # 打开的文件对象

content = file_obj.read()

输出结果如下:

在这里插入图片描述

demo.txt文档被打印出了。

如要查看read()函数说明的文本字符串:

help(file_obj.read) # 可以以这样的形式来查看read()函数的用法详情

结果如下:

在这里插入图片描述


2.2 读取中文 encoding参数


如果demo.txt文本文件中有中文,(比如现在我们在其中再写入一行“云雀叫了一整天”七个字。)

再运行上述代码则会报错:

在这里插入图片描述

我们需要在open()函数中加入参数encoding=‘utf-8’,才可读取。

  • (基础补充:Unicode及万国码 包含世界上所有语言和字符,编写程序一般都会使用Unicode编码。Unicode编码有多种实现: UTF-8 UTF-16 UTF-32。其中UTF-8支持的字符是最多的。UTF-16少一半,UTF-32又少一半。支持字符越多适用范围越广,支持字符越少越简洁高效。我们一般使用utf-8较多)

file_name = ‘demo.txt’

file_obj = open(file_name, encoding=‘utf-8’) # 打开的文件对象

content = file_obj.read()

结果正常打印出了:

在这里插入图片描述


2.3 较大文件的读取 readline()与readlines()


read()可以接收一个size作为参数,改参数用来指定读取字符的数量,默认为-1,表示读取全部内容。

file_name = ‘demo.txt’

file_obj = open(file_name, encoding=‘utf-8’) # 打开的文件对象

content = file_obj.read(25) # 读取25个字符

print(content)

结果:

在这里插入图片描述

如果读取的文件比较大的话,会一次性地讲文件加载到内容中。容易导致内存泄露。所有对于较大的文件通常不用read()函数读取。

readline()用于一行一行地读取,

readlines()用于一行一行地读取,一次性将读取到的内容封装到一个列表中返回。

file_name = ‘demo.txt’

try:

with open(file_name, encoding=‘utf-8’) as f: # 对于我们打开的这个文件对象取名为f

content = f.read(4) # 给size传递参数,一次读取多少个字节

content = f.readline() # 一行一行的读取,不再示例。

content = f.readlines() # 也是一行一行的读取,不过会读取完所有,并且存放到列表中

print(content)

except FileNotFoundError:

print(‘文件名没有找到’)

输出结果:

在这里插入图片描述


3. 文件的关闭

===============================================================================

  • 调用close()方法来关闭文件

  • with … as …语句自带关闭,不需要写close()。

示例如下:

file_name = ‘demo.txt’

file_obj = open(file_name, encoding=‘utf-8’) # 打开的文件对象

content = file_obj.read() # 文件读取

print(content)

file_obj.close() # 关闭文件之后就不能再继续读取了

con = file_obj.read() # 文件读取

print(con)

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

三、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
ark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA56iL5bqP5aqb56eD56eD,size_20,color_FFFFFF,t_70,g_se,x_16#pic_center)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
[外链图片转存中…(img-L0OTnHXC-1713364621320)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 24
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值