Python全栈之路系列之文件操作
Python可以对文件进行查看、创建等功能,可以对文件内容进行添加、修改、删除,且所使用到的函数在Python3.5.x为open
,在Python2.7.x同时支持file
和open
,但是在3.5.x系列移除了file
函数。
Python文件打开方式
文件句柄 = open('文件路径','打开模式')
Ps:文件句柄相当于于变量名,文件路径可以写为绝对路径也可以写为相对路径。
Python打开文件的模式
基本的模式
模式 | 说明 | 注意事项 |
---|---|---|
r | 只读模式 | 文件必须存在 |
w | 只写模式 | 文件不存在则创建文件,文件存在则清空文件内容 |
x | 只写模式 | 文件不可读,文件不存在则创建,存在则报错 |
a | 追加模式 | 文件不存在创建文件,文件存在则在文件末尾添加内容 |
带+
的模式
模式 | 说明 |
---|---|
r+ | 读写 |
w+ | 写读 |
x+ | 写读 |
a+ | 写读 |
带b
的模式
模式 | 说明 |
---|---|
rb | 二进制读模式 |
wb | 二进制写模式 |
xb | 二进制只写模式 |
ab | 二进制追加模式 |
提示:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型
带+
带b
的模式
模式 | 说明 |
---|---|
rb+ | 二进制读写模式 |
wb+ | 二进制读写模式 |
xb+ | 二进制只写模式 |
ab+ | 二进制读写模式 |
Python文件读取方式
模式 | 说明 |
---|---|
read([size]) | 读取文件全部内容,如果设置了size,那么久读取size字节 |
readline([size]) | 一行一行的读取 |
readlines() | 读取到的每一行内容作为列表中的一个元素 |
测试的文件名是hello.tx"
,文件内容为:
Hello Word! 123 abc 456 abc 789 abc
read
代码:
# 以只读的方式打开文件hello.txt f = open("hello.txt","r") # 读取文件内容赋值给变量c c = f.read() # 关闭文件 f.close() # 输出c的值 print(c)
输出结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py Hello Word! 123 abc 456 abc 789 abc
readline
代码:
# 以只读模式打开文件hello.txt f = open("hello.txt","r") # 读取第一行 c1 = f.readline() # 读取第二行 c2 = f.readline() # 读取第三行 c3 = f.readline() # 关闭文件 f.close() # 输出读取文件第一行内容 print(c1) # 输出读取文件第二行内容 print(c2) # 输出读取文件第三行内容 print(c3)
输出结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py Hello Word! 123 abc
readlines
# 以只读的方式打开文件hello.txt f = open("hello.txt","r") # 将文件所有内容赋值给c c = f.readlines() # 查看数据类型 print(type(c)) # 关闭文件 f.close() # 遍历输出文件内容 for n in c: print(n)
结果
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py # 输出的数据类型 <class 'list'> Hello Word! 123 abc 456 abc 789 abc
Python文件写入方式
方法 | 说明 |
---|---|
write(str) | 将字符串写入文件 |
writelines(sequence or strings) | 写多行到文件,参数可以是一个可迭代的对象,列表、元组等 |
write
代码:
# 以只读的模式打开文件write.txt,没有则创建,有则覆盖内容 file = open("write.txt","w") # 在文件内容中写入字符串test write file.write("test write") # 关闭文件 file.close()
write.txt
文件内容为:
test write
writelines
代码:
# 以只读模式打开一个不存在的文件wr_lines.txt f = open("wr_lines.txt","w",encoding="utf-8") # 写入一个列表 f.writelines(["11","22","33"]) # 关闭文件 f.close()
wr_lines.txt
文件内容:
112233
Python文件操作所提供的方法
close(self):
关闭已经打开的文件
f.close()
fileno(self):
文件描述符
f = open("hello.txt","r") ret = f.fileno() f.close() print(ret)
执行结果:
3
flush(self):
刷新缓冲区的内容到硬盘中
f.flush()
isatty(self):
判断文件是否是tty设备,如果是tty设备则返回True
,否则返回False
f = open("hello.txt","r") ret = f.isatty() f.close() print(ret)
返回结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py False
readable(self):
是否可读,如果可读返回True
,否则返回False
f = open("hello.txt","r") ret = f.readable() f.close() print(ret)
返回结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py True
readline(self, limit=-1):
每次仅读取一行数据
f = open("hello.txt","r") print(f.readline()) print(f.readline()) f.close()
返回结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py Hello Word! 123
readlines(self, hint=-1):
把每一行内容当作列表中的一个元素
f = open("hello.txt","r") print(f.readlines()) f.close()
返回结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py ['Hello Word!\n', '123\n', 'abc\n', '456\n', 'abc\n', '789\n', 'abc']
tell(self):
获取指针位置
f = open("hello.txt","r") print(f.tell()) f.close()
返回结果:
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py 0
seek(self, offset, whence=io.SEEK_SET):
指定文件中指针位置
f = open("hello.txt","r") print(f.tell()) f.seek(3) print(f.tell()) f.close()
执行结果
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py 0 3
seekable(self):
指针是否可操作
f = open("hello.txt","r") print(f.seekable()) f.close()
执行结果
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py True
writable(self):
是否可写
f = open("hello.txt","r") print(f.writable()) f.close()
执行结果
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py False
writelines(self, lines):
写入文件的字符串序列,序列可以是任何迭代的对象字符串生产,通常是一个字符串列表
。
f = open("wr_lines.txt","w") f.writelines(["11","22","33"]) f.close()
执行结果
112233
read(self, n=None):
读取指定字节数据,后面不加参数默认读取全部
f = open("wr_lines.txt","r") print(f.read(3)) f.seek(0) print(f.read()) f.close()
执行结果
C:\Python35\python.exe F:/Python_code/sublime/Day06/file.py 112 112233
write(self, s):
往文件里面写内容
f = open("wr_lines.txt","w") f.write("abcabcabc") f.close()
文件内容
abcabcabc
同时打开多个文件
为了避免打开文件后忘记关闭,可以通过管理上下文,即:
with open('log','r') as f: 代码块
如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。
在Python 2.7 及以后,with又支持同时对多个文件的上下文进行管理,即:
with open('log1') as obj1, open('log2') as obj2: pass
更多Python全栈之路系列之文件操作相关文章请关注PHP中文网!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

用大多数文本编辑器即可打开XML文件;若需更直观的树状展示,可使用 XML 编辑器,如 Oxygen XML Editor 或 XMLSpy;在程序中处理 XML 数据则需使用编程语言(如 Python)与 XML 库(如 xml.etree.ElementTree)来解析。

没有简单、直接的免费手机端XML转PDF工具。需要的数据可视化过程涉及复杂的数据理解和渲染,市面上所谓的“免费”工具大多体验较差。推荐使用电脑端的工具或借助云服务,或自行开发App以获得更靠谱的转换效果。

无法找到一款将 XML 直接转换为 PDF 的应用程序,因为它们是两种根本不同的格式。XML 用于存储数据,而 PDF 用于显示文档。要完成转换,可以使用编程语言和库,例如 Python 和 ReportLab,来解析 XML 数据并生成 PDF 文档。

直接在手机上将XML转换为PDF并不容易,但可以借助云端服务实现。推荐使用轻量级手机App上传XML文件并接收生成的PDF,配合云端API进行转换。云端API使用无服务器计算服务,选择合适的平台至关重要。处理XML解析和PDF生成时需要考虑复杂性、错误处理、安全性和优化策略。整个过程需要前端App与后端API协同工作,需要对多种技术有所了解。

修改XML内容需要编程,因为它需要精准找到目标节点才能增删改查。编程语言有相应库来处理XML,提供API像操作数据库一样进行安全、高效、可控的操作。

XML格式化工具可以将代码按照规则排版,提高可读性和理解性。选择工具时,要注意自定义能力、对特殊情况的处理、性能和易用性。常用的工具类型包括在线工具、IDE插件和命令行工具。

XML 美化本质上是提高其可读性,包括合理的缩进、换行和标签组织。其原理是通过遍历 XML 树,根据层级增加缩进,并处理空标签和包含文本的标签。Python 的 xml.etree.ElementTree 库提供了方便的 pretty_xml() 函数,可以实现上述美化过程。

不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。
