Python全栈之路:文件file常用操作

简介: Python全栈之路:文件file常用操作

文件模式mode

image.png

文件方法method


image.png

image.png

文件属性property

image.png

实例演示

文件操作:打开-操作-关闭


模式mode:

文本

r只读(默认)

w只写(创建新文件,存在则删除,不存在则新建)
a追加(不存在则创建,存在则追加)
“+”表示可以同时读写某个文件
r+读写(追加写,常用此项),w+写读(追加写),a+追加读(同a)
“b”二进制文件(没有encoding参数,网络传输,图片,声音,视频)
rb只读,rw只写,ra追加,rb+读写,rw+读写,ra+读写
“U”表示读取时,\r,\n,\r\n自动换成\n
rU只读
只读(默认)
"""春宫曲.txt
春宫曲
唐代:王昌龄
昨夜风开露井桃,未央前殿月轮高。
平阳歌舞新承宠,帘外春寒赐锦袍。
"""
f = open("春宫曲.txt", encoding="utf-8")  # 文件句柄
print(f.read())  # 读取全部内容
f.close()
"""
报错:
UnicodeDecodeError: 'gbk' codec can't decode byte 0xae in position 4: 
illegal multibyte sequence
设置:encoding="utf-8"
"""

只写,原来的内容被清空

f = open("春宫曲.txt", "w", encoding="utf-8")  # 指定编码
poetry = """春宫曲
唐代:王昌龄
昨夜风开露井桃,未央前殿月轮高。
平阳歌舞新承宠,帘外春寒赐锦袍。
"""
f.write(poetry)  # 写入
f.close()

追加

f = open("春宫曲.txt", "a", encoding="utf-8")
f.write("好诗好诗!")  # 在文件末尾追加写入
f.close()

读写文件

f = open("春宫曲.txt", "r+", encoding="utf-8")
#  只适合读取小文件,会转为列表(low loop,不推荐)
for index, line in enumerate(f.readlines()):
    if index == 1:  # 不打印文件第二行
        print("我是分割线".center(30, "*"))
        continue
    print(line.strip())  # 去除两侧空格和换行
f.write("写入内容,不会报错!")
f.close()

读写文件

f = open("春宫曲.txt", "r+", encoding="utf-8")
# high biger,推荐
count = 0  # 计数器
for line in f:  # f是一个迭代器
    count += 1
    if count == 2:  # 如果是第二行
        print("--------")
        continue
    print(line.strip())
f.close()

文件对象方法和属性

f = open("春宫曲.txt", "r+", encoding="utf-8")
print(f.tell())  # 文件指针位置 ->0
print(f.readline())  # ->春宫曲
print(f.tell())  # ->11
f.seek(0)  # 将文件指针移到文件首
print(f.tell())  # ->0
print(f.readline())  # ->春宫曲
print(f.fileno())  # 文件的描述符 ->3
print(type(f))  # -><class '_io.TextIOWrapper'>
print(f.name)  # 文件名 ->春宫曲.txt
print(f.mode)  # 打开模式 ->r+
print(f.closed)  # 是否关闭 ->False
print(f.encoding)  # 文件编码 ->utf-8
print(f.buffer)  # -><_io.BufferedRandom name='春宫曲.txt'>
print(type(f.newlines),f.newlines.encode("utf-8"))  # 文件换行符
# -><class 'str'> b'\r\n'
print(f.isatty())  # 检测文件是否连接到一个终端设备 ->False
f.truncate(10)  # 截断
f.flush()  # 将缓存内容刷入硬盘
# f.write("在增加点内容吧")
f.close()

二进制读写

f = open("春宫曲.txt", "rb+")  # 二进制读写的时候,不能指定编码
print(f.read())  # ->b'\xe6\x98\xa5\xe5\xae\xab\xe6\x9b\xb2\r'
f.write("我爱北京天安门".encode("utf-8"))  # 字符串转为字节再写入
f.close()

小知识

windows命令行下,切换盘符

C:\>d:

相关文章
|
3月前
|
数据可视化 Linux iOS开发
Python脚本转EXE文件实战指南:从原理到操作全解析
本教程详解如何将Python脚本打包为EXE文件,涵盖PyInstaller、auto-py-to-exe和cx_Freeze三种工具,包含实战案例与常见问题解决方案,助你轻松发布独立运行的Python程序。
1143 2
|
2月前
|
监控 机器人 编译器
如何将python代码打包成exe文件---PyInstaller打包之神
PyInstaller可将Python程序打包为独立可执行文件,无需用户安装Python环境。它自动分析代码依赖,整合解释器、库及资源,支持一键生成exe,方便分发。使用pip安装后,通过简单命令即可完成打包,适合各类项目部署。
|
4月前
|
缓存 数据可视化 Linux
Python文件/目录比较实战:排除特定类型的实用技巧
本文通过四个实战案例,详解如何使用Python比较目录差异并灵活排除特定文件,涵盖基础比较、大文件处理、跨平台适配与可视化报告生成,助力开发者高效完成目录同步与数据校验任务。
178 0
|
5月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
5月前
|
编译器 Python
如何利用Python批量重命名文件
本文介绍了如何使用Python和PyCharm对文件进行批量重命名,包括文件名前后互换、按特定字符调整顺序等实用技巧,并提供了完整代码示例。同时推荐了第三方工具Bulk Rename Utility,便于无需编程实现高效重命名。适用于需要处理大量文件命名的场景,提升工作效率。
|
5月前
|
安全 Linux 网络安全
Python极速搭建局域网文件共享服务器:一行命令实现HTTPS安全传输
本文介绍如何利用Python的http.server模块,通过一行命令快速搭建支持HTTPS的安全文件下载服务器,无需第三方工具,3分钟部署,保障局域网文件共享的隐私与安全。
1140 0
|
6月前
|
编解码 Prometheus Java
当Python同时操作1000个文件时,为什么你的CPU只用了10%?
本文介绍如何构建一个高效的文件处理系统,解决单线程效率低、多线程易崩溃的矛盾。通过异步队列与多线程池结合,实现任务调度优化,提升I/O密集型操作的性能。
153 4
|
5月前
|
数据管理 开发工具 索引
在Python中借助Everything工具实现高效文件搜索的方法
使用上述方法,你就能在Python中利用Everything的强大搜索能力实现快速的文件搜索,这对于需要在大量文件中进行快速查找的场景尤其有用。此外,利用Python脚本可以灵活地将这一功能集成到更复杂的应用程序中,增强了自动化处理和数据管理的能力。
436 0
|
5月前
|
数据采集 监控 算法
Python文件与目录比较全攻略:从基础操作到性能优化
文件比较的核心在于数据指纹校验,通过逐字节比对生成唯一标识,确保内容一致性。从标准库的os与filecmp到高性能第三方库如pydiffx,再到分布式与量子加密技术的未来趋势,文件比较广泛应用于数据备份、代码审查与系统监控等领域,是保障数据完整性的关键技术手段。
126 0
|
6月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件

推荐镜像

更多