一学就废|Python基础碎片,文件读写
liuian 2025-04-11 00:59 14 浏览
文件处理是指通过编程接口对文件执行诸如创建、打开、读取、写入和关闭等操作的过程。它涉及管理程序与存储设备上的文件系统之间的数据流,确保数据得到安全高效的处理。
Python 中的文件模式
打开文件时,我们必须指定我们想要的模式,该模式指定我们想要对文件做什么。不同模式的说明如下:
模式 | 说明 |
r | 读取模式。打开一个文件用于读取。文件必须存在。 |
w | 写入模式。打开文件以进行写入。如果文件不存在则创建新文件,如果文件已存在则截断文件。 |
a | 追加模式。打开文件以追加内容。如果文件不存在则创建一个新文件。 |
b | 二进制模式。以二进制模式打开文件。 |
t | 文本模式。以文本模式打开文件。默认模式。 |
x | 独家创建模式。创建一个新文件,如果文件已存在则失败。 |
r+ | 读写模式。打开一个文件以进行读取和写入。文件必须存在。 |
w+ | 写和读模式。打开文件以进行写入和读取。如果文件不存在则创建新文件,如果文件存在则截断文件。 |
a+ | 追加和读取模式。打开文件以追加和读取内容。如果文件不存在,则创建一个新文件。 |
我们使用的文本文件内容如下:
中华人民共和国
文件内容读取
python学习
在 Python 中打开文件
打开文件,我们可以使用 open()函数,它需要文件路径和模式作为参数:
# Open the file and read its contents
with open('test.txt', 'r') as file:
读取文件
读取文件可以通过 file.read()来实现,它读取文件的全部内容。读取文件后,我们可以使用 file. off()关闭文件,它在读取文件后关闭文件,这是释放系统资源所必需的。
以只读模式(r)读取文件。
file = open("test.txt", "r")
content = file.read()
print(content)
file.close()
中华人民共和国
文件内容读取
python学习
以二进制模式(rb)读取文件
file = open("test.txt", "rb")
content = file.read()
print(content)
file.close()
b'\xd6\xd0\xbb\xaa\xc8\xcb\xc3\xf1\xb9\xb2\xba\xcd\xb9\xfa\r\n\xce\xc4\xbc\xfe\xc4\xda\xc8\xdd\xb6\xc1\xc8\xa1\r\npython\xd1\xa7\xcf\xb0'
逐行读取
我们可能希望逐行读取文件,尤其是对于一次读取整个内容并不实用的大文件。它通过以下两种方法完成:
- for line in file:遍历文件中的每一行。
- line.strip():删除任何前导或尾随空格,包括换行符。
# Open the file in read mode
file = open("test.txt", "r")
# Read each line one by one
for line in file:
print(line.strip()) # .strip() to remove newline characters
# Close the file
file.close()
也可以使用file. readline() 一次读取一行。
# Open the file in read mode
file = open("test.txt", "r")
# Read the first line
line = file.readline()
while line:
print(line.strip())
line = file.readline() # Read the next line
# Close the file
file.close()
读取 CSV 文件
读取 CSV(逗号分隔值)文件是处理表格数据的常见任务。Python 的 csv 模块使读取 CSV 文件变得容易。
import csv
# Open the CSV file
with open("test.csv", newline='') as csvfile:
# Create a CSV reader object
csvreader = csv.reader(csvfile)
# Read and print each row
for row in csvreader:
print(row)
读取 JSON 文件
读取 JSON(JavaScript Object Notation)文件广泛用于数据交换。Python 的 json 模块提供了读取 JSON 文件的方法。
import json
# Open the JSON file
with open("test.json", "r") as jsonfile:
# Load the JSON data
data = json.load(jsonfile)
# Print the data
print(data)
写入文件
写入文件是使用 file. write()完成的,它将指定的字符串写入文件。如果文件存在,则删除其内容。如果它不存在,则创建一个新文件。
以写入模式(w)写入文件
file = open("write_test.txt", "w")
file.write("Hello, World!")
file.close()
以追加模式(a)写入文件。
# Python code to illustrate append() mode
file = open('write_test.txt', 'a')
file.write("This will add this line")
file.close()
关闭文件
关闭文件对于确保正确释放文件使用的所有资源至关重要。file. off()方法关闭文件并确保保存对文件所做的任何更改。
file = open("test.txt", "r")
# Perform file operations
file.close()
使用with句式
with 语句用于资源管理。它确保文件在其套件完成后正确关闭,即使出现异常。使用 open()as 方法会在退出代码块后自动处理关闭文件,即使发生错误。这降低了文件损坏和资源泄漏的风险。
with open("test.txt", "r") as file:
content = file.read()
print(content)
关闭文件时处理异常
处理异常很重要,这样可以确保即使在文件操作过程中发生错误,文件也能被正确关闭。
try:
file = open("test.txt", "r")
content = file.read()
print(content)
finally:
file.close()
Python 中文件处理的优势
- 多功能性:Python 中的文件处理允许我们执行广泛的操作,例如创建、读取、写入、附加、重命名和删除文件。
- 灵活性:Python 中的文件处理非常灵活,因为它允许我们处理不同的文件类型(例如文本文件、二进制文件、CSV 文件等),并对文件执行不同的操作(例如读取、写入、附加等)。
- 用户友好:Python 为文件处理提供了用户友好的界面,使创建、读取和操作文件变得容易。
- 跨平台:Python 文件处理功能可跨不同平台(例如 Windows、Mac、Linux)工作,允许无缝集成和兼容性。
Python 中文件处理的缺点
- 容易出错:Python 中的文件处理操作可能容易出错,特别是如果代码编写不仔细或文件系统存在问题(例如文件权限、文件锁等)。
- 安全风险:Python 中的文件处理也可能带来安全风险,特别是如果程序接受可用于访问或修改系统上敏感文件的用户输入。
- 复杂性:Python 中的文件处理可能很复杂,尤其是在使用更高级的文件格式或操作时。必须仔细注意代码,以确保正确安全地处理文件。
- 性能:Python 中的文件处理操作可能比其他编程语言慢,尤其是在处理大文件或执行复杂操作时。
相关推荐
- GANs为何引爆机器学习?这篇基于TensorFlow的实例教程为你解惑!
-
「机器人圈导览」:生成对抗网络无疑是机器学习领域近三年来最火爆的研究领域,相关论文层出不求,各种领域的应用层出不穷。那么,GAN到底如何实践?本文编译自Medium,该文作者以一朵玫瑰花为例,详细阐...
- 高丽大学等机构联合发布StarGAN:可自定义表情和面部特征
-
原文来源:arXiv、GitHub作者:YunjeyChoi、MinjeChoi、MunyoungKim、Jung-WooHa、SungKim、JaegulChoo「雷克世界」编译:嗯~...
- TensorFlow和PyTorch相继发布最新版,有何变化
-
原文来源:GitHub「机器人圈」编译:嗯~阿童木呀、多啦A亮Tensorflow主要特征和改进在Tensorflow库中添加封装评估量。所添加的评估量列表如下:1.深度神经网络分类器(DNNCl...
- 「2022 年」崔庆才 Python3 爬虫教程 - 深度学习识别滑动验证码缺口
-
上一节我们使用OpenCV识别了图形验证码躯壳欧。这时候就有朋友可能会说了,现在深度学习不是对图像识别很准吗?那深度学习可以用在识别滑动验证码缺口位置吗?当然也是可以的,本节我们就来了解下使用深度...
- 20K star!搞定 LLM 微调的开源利器
-
LLM(大语言模型)微调一直都是老大难问题,不仅因为微调需要大量的计算资源,而且微调的方法也很多,要去尝试每种方法的效果,需要安装大量的第三方库和依赖,甚至要接入一些框架,可能在还没开始微调就已经因为...
- 大模型DeepSeek本地部署后如何进行自定义调整?
-
1.理解模型架构a)查看深度求索官方文档或提供的源代码文件,了解模型的结构、输入输出格式以及支持的功能。模型是否为预训练权重?如果是,可以在预训练的基础上进行微调(Fine-tuning)。是否需要...
- 因配置不当,约5000个AI模型与数据集在公网暴露
-
除了可访问机器学习模型外,暴露的数据还可能包括训练数据集、超参数,甚至是用于构建模型的原始数据。前情回顾·人工智能安全动态向ChatGPT植入恶意“长期记忆”,持续窃取用户输入数据多模态大语言模型的致...
- 基于pytorch的深度学习人员重识别
-
基于pytorch的深度学习人员重识别Torchreid是一个库。基于pytorch的深度学习人员重识别。特点:支持多GPU训练支持图像的人员重识别与视频的人员重识别端到端的训练与评估简单的re...
- DeepSeek本地部署:轻松训练你的AI模型
-
引言:为什么选择本地部署?在AI技术飞速发展的今天,越来越多的企业和个人希望将AI技术应用于实际场景中。然而,对于一些对数据隐私和计算资源有特殊需求的用户来说,云端部署可能并不是最佳选择。此时,本地部...
- 谷歌今天又开源了,这次是Sketch-RNN
-
前不久,谷歌公布了一项最新技术,可以教机器画画。今天,谷歌开源了代码。在我们研究其代码之前,首先先按要求设置Magenta环境。(https://github.com/tensorflow/magen...
- Tensorflow 使用预训练模型训练的完整流程
-
前面已经介绍了深度学习框架Tensorflow的图像的标注和训练数据的准备工作,本文介绍一下使用预训练模型完成训练并导出训练的模型。1.选择预训练模型1.1下载预训练模型首先需要在Tensorf...
- 30天大模型调优学习计划(30分钟训练大模型)
-
30天大模型调优学习计划,结合Unsloth和Lora进行大模型微调,掌握大模型基础知识和调优方法,熟练应用。第1周:基础入门目标:了解大模型基础并熟悉Unsloth等工具的基本使用。Day1:大模...
- python爬取喜马拉雅音频,json参数解析
-
一.抓包分析json,获取加密方式1.抓包获取音频界面f12打开抓包工具,播放一个(非vip)视频,点击“媒体”单击打开可以复制URL,发现就是我们要的音频。复制“CKwRIJEEXn-cABa0Tg...
- 五、JSONPath使用(Python)(json数据python)
-
1.安装方法pipinstalljsonpath2.jsonpath与Xpath下面表格是jsonpath语法与Xpath的完整概述和比较。Xpathjsonpath概述/$根节点.@当前节点...
- Python网络爬虫的时候json=就是让你少写个json.dumps()
-
大家好,我是皮皮。一、前言前几天在Python白银交流群【空翼】问了一个Python网络爬虫的问题,提问截图如下:登录请求地址是这个:二、实现过程这里【甯同学】给了一个提示,如下所示:估计很多小伙伴和...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- vscode美化代码 (33)
- python bytes转16进制 (35)