Python学不会来打我(43)文本、图片、视频的读取、写入、复制
itomcoil 2025-07-02 21:19 12 浏览
在Python编程中,文件操作 是非常基础且重要的技能。无论是处理日志、配置文件、用户数据,还是进行数据分析、图像处理、视频剪辑等任务,我们都需要与文件打交道。
本文将详细介绍 Python中对文本、图片、视频三类常见文件的操作方法,包括:
- 文件的读取与写入
- 文件的复制与移动
- 文本内容中查找某个关键词
- 实战示例帮助理解应用场景
文章内容适合 Python初学者 学习使用,也适合有一定基础的开发者作为参考手册查阅。我们将通过大量代码示例帮助你掌握这些实用技巧。
一、Python中常用的文件操作模块
Python标准库提供了多个用于文件操作的模块,常见的有:
二、文本文件的操作
1. 读取文本文件
with open("example.txt", "r",
encoding="utf-8") as f:
content = f.read()
print(content)
说明:
- "r" 表示只读模式
- encoding="utf-8" 是推荐的编码格式
- 使用 with 关键字可以自动关闭文件
2. 写入文本文件
with open("output.txt", "w",
encoding="utf-8") as f:
f.write("Hello, World!\n")
f.write("这是第二行\n")
- "w" 表示写入模式,如果文件不存在则创建,存在则清空内容
- 每次调用 write() 会写入字符串内容
3. 追加内容到文件末尾
with open("output.txt", "a",
encoding="utf-8") as f:
f.write("这是新增的一行\n")
- "a" 表示追加模式,不会清除原有内容
4. 查找某个文字或关键词(全文匹配)
with open("example.txt", "r",
encoding="utf-8") as f:
content = f.read()
if "Python" in content:
print("找到了关键词 'Python'")
else:
print("未找到该关键词")
5. 查找所有出现的关键词(正则表达式)
import re
with open("example.txt", "r", encoding="utf-8") as f:
content = f.read()
matches = re.findall(r"Python", content)
print(f"共找到 {len(matches)} 个关键词 'Python'")
三、图片文件的操作(使用 Pillow)
安装依赖:
pip install pillow
1. 打开并显示图片
from PIL import Image
img = Image.open("photo.jpg")
img.show() # 显示图片
2. 保存图片为其他格式
img.save("photo.png")
3. 复制图片文件
import shutil
shutil.copy("photo.jpg", "backup_photo.jpg")
4. 获取图片基本信息
print("格式:", img.format)
# 输出格式:JPEG/PNG 等
print("尺寸:", img.size)
# 输出宽高
print("颜色模式:", img.mode)
# RGB / L 等
四、视频文件的操作(使用 OpenCV)
安装依赖:
pip install opencv-python
1. 读取视频文件信息
import cv2
cap = cv2.VideoCapture("video.mp4")
if cap.isOpened():
fps = cap.get(cv2.CAP_PROP_FPS)
width = int(cap.get(cv2.CAP_PROP_FRAME_WIDTH))
height = int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT))
print(f"帧率: {fps}, 尺寸: {width}x{height}")
2. 逐帧读取视频并保存为图像
frame_count = 0
while True:
ret, frame = cap.read()
if not ret:
break
cv2.imwrite(f"frames/frame_{frame_count}.jpg", frame)
frame_count += 1
cap.release()
3. 视频文件复制
import shutil
shutil.copy("video.mp4", "backup_video.mp4")
五、文件的复制与查找功能整合应用
场景1:查找包含“错误”关键词的日志文件,并复制到指定目录
import os
import shutil
import re
def find_and_copy_logs(keyword, source_dir, target_dir):
if not os.path.exists(target_dir):
os.makedirs(target_dir)
for filename in os.listdir(source_dir):
if filename.endswith(".log"):
file_path = os.path.join(source_dir, filename)
with open(file_path, "r", encoding="utf-8", errors='ignore') as f:
content = f.read()
if re.search(keyword, content):
shutil.copy(file_path, target_dir)
print(f"已复制文件: {filename}")
find_and_copy_logs("错误", "logs", "error_logs")
场景2:批量重命名图片文件并复制到新目录
import os
import shutil
def rename_and_copy_images(source_folder,
dest_folder):
if not os.path.exists(dest_folder):
os.makedirs(dest_folder)
count = 1
for filename in os.listdir(source_folder):
if filename.lower().endswith(('.png', '.jpg', '.jpeg')):
src = os.path.join(source_folder, filename)
dst = os.path.join(dest_folder,
f"image_{count}{os.path.splitext(filename)[1]}")
shutil.copy(src, dst)
count += 1
rename_and_copy_images("images", "renamed_images")
六、注意事项与最佳实践
最佳实践:
- 使用 with open(...) 结构确保文件正确关闭
- 对于大文件建议逐行读取,避免内存溢出
- 图片和视频操作前先确认文件格式是否支持
- 使用 try-except 捕获异常,增强程序健壮性
常见问题:
- 权限错误:确保运行程序时对目标文件有读写权限
- 编码错误:读取非UTF-8文件时要指定正确的编码格式(如 latin-1)
- 路径错误:相对路径容易出错,建议使用 os.path.abspath() 或 Path.resolve()
- 并发访问冲突:多线程或多进程环境下要注意文件锁机制
七、总结
通过本文的学习,你应该已经掌握了以下知识:
- 如何读取、写入、复制各种类型的文件(文本、图片、视频)
- 如何查找文本中的关键词(使用 in 和 re 模块)
- 如何使用第三方库(如 Pillow、OpenCV)处理图片和视频
- 如何将文件操作整合进实际项目(如日志分析、批量处理等)
- 文件操作的最佳实践和注意事项
Python 的文件模块功能强大且灵活,熟练掌握这些技能对于日常开发、自动化脚本编写、数据处理等都至关重要。
希望这篇文章能帮助你在 Python 编程之路上越走越远!
相关推荐
- selenium(WEB自动化工具)
-
定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...
- 开发利器丨如何使用ELK设计微服务中的日志收集方案?
-
【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...
- 高并发系统设计:应对每秒数万QPS的架构策略
-
当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...
- 2025 年每个 JavaScript 开发者都应该了解的功能
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...
- JavaScript Array 对象
-
Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...
- Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战
-
刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...
- 动力节点最新JavaScript教程(高级篇),深入学习JavaScript
-
JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...
- 一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code
-
当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...
- 「晚安·好梦」努力只能及格,拼命才能优秀
-
欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...
- JavaScript 中 some 与 every 方法的区别是什么?
-
大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...
- 10个高效的Python爬虫框架,你用过几个?
-
小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...
- 12个高效的Python爬虫框架,你用过几个?
-
实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...
- pip3 install pyspider报错问题解决
-
运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...
- PySpider框架的使用
-
PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...
- 「机器学习」神经网络的激活函数、并通过python实现激活函数
-
神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)