第9.12节 Python中其他文件操作方式
一、 引言
本章老猿主要介绍了Python 内置io模块的文件操作相关功能,其实除了内置io模块可以进行文件操作外,Python的不同模块还提供了多种文件操作方式,下面简单将这些模块和方法介绍一下。
二、 使用上下文管理器打开文件读写
上下文管理器老猿还没学过,暂时也没想花时间去研究,在这里大家记住使用方法就可以了。
- 语法:
with open(文件名,读写模式) as 文件对象:
对文件对象进行操作。 - 语法释义
1)使用with…as语句来开启上下文管理器;
2)open就是io模块的open,语法也是一样;
3)文件对象就是open返回的文件对象。
从以上语法来看,使用上下文管理器实际上与直接使用open差不多,只是将文件对象放到了as后面,同时文件读取后不需要取关闭,上下文管理器会自动关闭文件
三、 使用fileinput按行读取文件
fileinput属于fileinput模块,因此使用前需要导入该模块。
- 语法:
fileinput.input(文件名) - 语法释义:
打开文件名指定的文件,返回一个fileinput.FileInput的对象,该对象可以使用readline读取文件内容,同时该对象还是一个可操作文件的迭代对象,直接使用for…in进行迭代读取文件内容。如:
for line in fileinput.input(filename):print(line)
四、 将打开的文件使用迭代访问方式处理
fileinput.input打开的文件可以通过迭代方式访问,实际上open打开的文件也可以:
1、 使用上下文管理打开文件后迭代读取,如:
with open(r’c:\temp\test.txt’) as f:
for line in f:print(line)
2、 直接打开文件迭代读取
for line in open(r’c:\temp\test.txt’)::print(line)
注意:文件访问后不会关闭
五、 使用os模块进行文件操作
在前面章节介绍open函数时,我们提及了os模块的open函数,实际上os模块有完整的读写、定位函数,只是都是底层的操作函数。
1、 os.open(path, flags, mode=0o777, *, dir_fd=None)打开文件,返回一个文件描述符
2、 os.lseek(fd, pos, how)进行文件指针定位;
3、 os.read(fd, n)读取文件
4、 os.write(fd, str)写入文件
5、 os.fchown(fd, uid, gid)改变文件的归属用户和归属组
6、 os.close(fd)关闭文件
具体每个函数的参数释义老猿在此不详细介绍,请大家参考Python官网os模块的文档:https://docs.python.org/zh-cn/3/library/os.html#module-os
六、 使用shelve模块操作文件
shelve模块是个特殊的文件操作模块,因为它对应的文件用于存储字典数据。使用时,先使用shelve.open打开文件,返回一个shelve.DbfilenameShelf,使用这个对象就像使用一个字典一样。举例:
>>> import shelve
>>> f=shelve.open(r"c:\temp\d.txt")
>>> f['1']=[10,11,12]
>>> f['2']=[20,21,22]
>>> f.close()
>>> type(f)
<class 'shelve.DbfilenameShelf'>
>>>
具体语法请参见Python官网:https://docs.python.org/zh-cn/3/library/shelve.html#module-shelve
本节老猿介绍了几种有别于前面介绍的io模块文件操作的文件操作方法,包括使用io模块进行文件迭代访问,在某些场景下可以使得写的代码很精干。
老猿Python,跟老猿学Python!
博客地址:https://blog.csdn.net/LaoYuanPython
请大家多多支持,点赞、评论和加关注!谢谢!
第9.12节 Python中其他文件操作方式的更多相关文章
- 第14.12节 Python中使用BeautifulSoup解析http报文:使用select方法快速定位内容
一. 引言 在<第14.10节 Python中使用BeautifulSoup解析http报文:html标签相关属性的访问>和<第14.11节 Python中使用BeautifulSo ...
- 第14.11节 Python中使用BeautifulSoup解析http报文:使用查找方法快速定位内容
一. 引言 在<第14.10节 Python中使用BeautifulSoup解析http报文:html标签相关属性的访问>介绍了BeautifulSoup对象的主要属性,通过这些属性可以访 ...
- python中对文件、文件夹,目录的基本操作
一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法.1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()2.返回指定目录下的所有文件和目 ...
- 第8.23节 Python中使用sort/sorted排序与“富比较”方法的关系分析
一. 引言 <第8.21节 Python中__lt__.gt__等 "富比较"("rich comparison")方法用途探究>和<第8.2 ...
- 第8.28节 Python中使用__setattr__定义实例变量和实例方法
一. 引言 根据前面章节介绍的内容,我们知道实例变量.实例方法的定义可以通过以下方法进行: 在类体中直接定义实例变量.实例方法: 在实例方法中定义实例变量.实例方法: 在类体外调用方使用赋值语句赋值定 ...
- 第14.10节 Python中使用BeautifulSoup解析http报文:html标签相关属性的访问
一. 引言 在<第14.8节 Python中使用BeautifulSoup加载HTML报文>中介绍使用BeautifulSoup的安装.导入和创建对象的过程,本节介绍导入后利用Beauti ...
- 第14.8节 Python中使用BeautifulSoup加载HTML报文
一. 引言 BeautifulSoup是一个三方模块bs4中提供的进行HTML解析的类,可以认为是一个HTML解析工具箱,对HTML报文中的标签具有比较好的容错识别功能.阅读本节需要了解html相关的 ...
- 关于Python中的文件操作(转)
总是记不住API.昨晚写的时候用到了这些,但是没记住,于是就索性整理一下吧: python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Pyth ...
- python中 对文件的读写操作 以及如何边写入 边保存flush()
转自:https://blog.csdn.net/t8116189520/article/details/78854708 首先 python中打开文件大致常用的几类如下: 1.写入文件write # ...
随机推荐
- 《GNU_makefile》第七章——makefile的条件执行
条件执行即,通过变量的值,来控制make的执行和忽略. 条件执行只能控制makefile的make语法部分,不能控制shell部分 1.一个例子 - libs_for_gcc = -lgnu norm ...
- UNP——第二章,TCP握手与挥手分析
1.握手 说明: 下面涉及 FIN,SYN,ACK之类数据时,都是由TCP服务收发, 涉及 accept, listen 之类api,都是 应用进程 完成. 都统一使用 客户端,服务端描述,请自行分辨 ...
- ceph与flashcache的around模式结合启动问题
问题 通过对我们的启动流程看了下,目前是穿到一个脚本里面的,然后这个脚本是用无限循环的方式去执行一些事情,这个地方不符合松耦合的设计,一个模块做一个事情,两个并不相关的功能不要嵌入另一个脚本,否则出现 ...
- kettle——转换案例
把stu1的数据按id同步到stu2,stu2有相同id则更新数据 (1)在mysql中创建两张表 mysql> create database kettle; mysql> use ke ...
- 通过ip访问项目
- 都0202了,还在问Vegas和Pr哪个好?
自媒体时代,蕴藏着很多机会.许多平凡的人,通过制作视频,收获了掌声.赢得了粉丝,甚至改变了自己的命运. 图1:B站百大UP主颁奖现场 但这条路真的一路畅通吗?其实不然,他们成功的背后,必定有多方面 ...
- 给PDF批量添加文本链接
为了进一步补充说明文件中的一些重要内容,PDF文件的创建者会为一些文本创建链接,方便阅读者访问相关的网站,获取更多的信息. 我们可以通过使用pdfFactory文本链接功能来实现以上需求,另外,我们还 ...
- 你也想当流量UP主?那就点开看看吧!
2009年6月份,哔哩哔哩(B站)在一众期待中诞生,它汇聚了天南海北当时小众的二次元同好,它也存在诸多不足,大家亲切地叫它"小破站". 而如今,它成长为一棵枝繁叶茂的参天大树,成为 ...
- python中正则表达式
正则表达式是一种通用的字符串匹配技术,是不会因为编程语言不一样而发生变化的如果想查找对应规则的字符串,就可以用正则表达式python中要使用正则表达式需使用re模块,它是正则表达式在python中的封 ...
- nginx学习http_access_module模块
location ~ ^/1.html { root /opt/app/code; deny XXXXX; #这个ip不能访问1.html allow all; #其他的可以访问这个页面1.html ...