百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python文件操作:读写txt/csv/json的终极方案

off999 2025-07-19 21:58 6 浏览 0 评论

在 Python 编程的世界里,文件操作是一项极为基础且关键的技能。无论是读取配置信息、存储处理结果,还是进行数据分析,我们都离不开对各种文件格式的读写操作。今天,就来给大家分享 Python 文件操作中读写 txt、csv、json 这三种常见文件格式的终极方案,希望能帮到正在学习 Python 的小伙伴们!

一、读写 txt 文件

(一)读取 txt 文件

  1. 读取整个文件内容

在 Python 中,使用内置的open函数可以轻松打开一个文件。当我们想要一次性读取整个 txt 文件的内容时,可以这样做:

file_path = 'example.txt'
with open(file_path, 'r', encoding='utf - 8') as file:
    content = file.read()
    print(content)

这里使用with语句,它就像是一个智能的管家,会在代码块结束时自动帮我们关闭文件,无需手动调file.close(),从而避免了因忘记关闭文件而可能导致的资源泄漏问题。'r'表示以只读模式打开文件,encoding='utf - 8'则指定了文件的编码格式,这样可以正确处理包含中文等非 ASCII 字符的文本文件。

  1. 逐行读取文件内容

当文件比较大时,一次性读取整个文件可能会占用过多内存,此时逐行读取是个更好的选择:

file_path = 'example.txt'
with open(file_path, 'r', encoding='utf - 8') as file:
    for line in file:
        print(line.strip())

在这个代码中,file本身就是一个可迭代对象,我们可以直接使for循环来逐行遍历它。line.strip()用于去除每行末尾的换行符及可能存在的空白字符,使输出结果更加整洁。

(二)写入 txt 文件

  1. 覆盖写入

如果要将内容写入一个新的 txt 文件,或者覆盖掉原有文件的内容,可以将打开文件的模式设置为'w':

file_path = 'output.txt'
with open(file_path, 'w', encoding='utf - 8') as file:
    file.write('Hello, Python!\n')
    file.write('This is a guide to file operations in Python.')

上述代码会创建一个名output.txt的文件(如果文件已存在则会被覆盖),并将两行文本写入其中。注意,每次调file.write()时,内容会直接追加到文件指针当前所在的位置。如果希望每次写入新内容时都换行,可以像示例中那样在字符串末尾加上'\n'。

  1. 追加写入

要是不想覆盖原有文件内容,而是在文件末尾追加新的内容,那么打开文件的模式应设为'a':

file_path = 'output.txt'
with open(file_path, 'a', encoding='utf - 8') as file:
    file.write('\nThis is an appended line.')

这样,新的文本就会被追加到output.txt文件的末尾,原有内容得以保留。

二、读写 csv 文件

(一)读取 csv 文件

CSV(Comma - Separated Values)文件是一种常用的表格数据存储格式,以纯文本形式存储数据,数据之间通常用逗号分隔。在 Python 中,我们可以使用内置的csv模块来处理 csv 文件。

import csv
file_path = 'example.csv'
with open(file_path, 'r', encoding='utf - 8') as file:
    reader = csv.reader(file)
    for row in reader:
        print(row)

这里通过csv.reader(file)创建了一个reader对象,它可以迭代读取example.csv文件的每一行数据,并将每行数据作为一个列表返回。如果 csv 文件的分隔符不是逗号,比如是分号;,可以通过指定delimiter参数来修改,即csv.reader(file, delimiter=';') 。

(二)写入 csv 文件

写入 csv 文件同样使csv模块,并且可以通csv.writer对象来实现。

import csv
file_path = 'output.csv'
data = [
    ('Name', 'Age'),
    ('Alice', 25),
    ('Bob', 30)
]
with open(file_path, 'w', encoding='utf - 8', newline='') as file:
    writer = csv.writer(file)
    writer.writerows(data)

在这段代码中,首先定义了一个包含表格数据的列表data,每个元素也是一个列表,表示表格的一行。然后通过csv.writer(file)创建了一个writer对象,使用writer.writerows(data)方法可以一次性将整个二维列表的数据写入到output.csv文件中。这里的newline=''参数很重要,它可以避免在写入 CSV 文件时出现多余的空行。如果只是想写入一行数据,可以使用writer.writerow(row)方法,其中row是一个表示单行数据的列表 。

三、读写 json 文件

(一)读取 json 文件

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,在 Web 开发、数据存储等领域广泛应用。Python 内置的json模块提供了处理 json 文件的功能。

import json
file_path = 'example.json'
with open(file_path, 'r', encoding='utf - 8') as file:
    data = json.load(file)
    print(data)

上述代码通过json.load(file)方法从example.json文件中读取 JSON 数据,并将其解析为对应的 Python 对象(通常是字典或列表)。例如,如果example.json文件内容为{"name": "张三", "age": 20},那么读取后data就是一个字典{'name': '张三', 'age': 20} 。

(二)写入 json 文件

将 Python 对象转换为 JSON 格式并写入文件也很简单。

import json
file_path = 'output.json'
data = {'name': 'John', 'age': 28}
with open(file_path, 'w', encoding='utf - 8') as file:
    json.dump(data, file, ensure_ascii=False, indent=4)

这里json.dump(data, file, ensure_ascii=False, indent=4)将字典data转换为 JSON 格式并写入output.json文件。ensure_ascii=False参数确保中文字符能正确写入文件而不是被转义为 ASCII 码;indent=4则使生成的 JSON 文件内容更加美观,以 4 个空格的缩进展示层级结构。

以上就是 Python 中读写 txt、csv、json 文件的常用方法啦,希望这些内容能帮助大家在文件操作的过程中更加得心应手!大家在实际使用过程中有没有遇到过什么有趣的问题或者有更好的实践经验呢?欢迎在评论区留言分享哦!

#Python# #txt# #csv# #json# #编程学习# #数据分析# #办公自动化# #爬虫#

相关推荐

一文搞清 Python 中方法和函数之间的区别

在我们使用Python的过程中,经常涉及到方法和函数,那他们有什么不同吗?在本文中,让我们通过示例了解Python中方法和函数之间的区别。Python函数Python函数是一系列以特定顺序...

Python 数据分析 + 可视化实战:5 分钟出图表,老板看了直点赞

还在用Excel做数据分析?效率太低了!同样一份销售数据,同事用Python半小时出报告,图表炫酷还能自动更新;你用Excel捣鼓大半天,稍微改点数据就得重新做图。今天教你用Python...

Python每日一库之Pendulum(python penup)

关于日期处理,Python提供了许多库,例如标准库datetime、第三方库dateutil、Arrow等。在这篇文章中,我想介绍我个人最喜欢的库pendulum,它使用非常方便,它可以满足...

Python计算两个日期相差天数 M + ACT/360模式,银行计算利息用

一般银行在计算计息的时候,都会用到M+ACT/360模式,也就是满1个月按30天计算,不足一个月按实际天数计算。一年算360天。例如:计算20151018到20190817相差的天数,201...

Python 之 MySql 每日一练 32——查询每门课程的平均成绩

一、表名和字段–1.学生表student(s_id,s_name,s_birth,s_sex)–学生编号,学生姓名,出生年月,学生性别–2.课程表course(c_id,c_name,t...

用Python制作数据报告:如何自动生成PDF格式的报告?

最近在琢磨数据分析工作的自动化,手动做报告真是太费劲啦!试过用Python整了个自动生成PDF报告的小工具,效果还不错。今天就聊聊怎么用Python把数据处理、可视化和PDF生成一条龙搞定。repor...

Github 1.2k star,一个好用的 Python 库-pyexcel!

大家好,今天为大家分享一个好用的Python库-pyexcel。Github地址:https://github.com/pyexcel/pyexcelpyexcel是一个功能强大的Python...

使用python写一个简单的到期事件钉钉提醒功能

前言:学习python第3天需求:简单的事件提醒功能版本:python3.9、mysql5.71、现在mysql建一个表event_remindCREATETABLE`event_remind`...

python定时任务最强框架APScheduler详细教程

APScheduler定时任务上次测试女神听了我的建议,已经做好了要给项目添加定时任务的决定了。但是之前提供的四种方式中,她不知道具体选择哪一个。为了和女神更近一步,我把我入行近10年收藏的干货免费拿...

解放双手,一键运行!Python每日自动生成数据日报

对于一个企业来说,高层看意义,中层看结论,基层看落地,数据日报、周报、月报可以监控销售个人在实际执行过程中的销售动态,而数据季度报、年报可以反映一个销售策略是否与实际的业务场景切合。可见数据日报在我们...

Python模块datetime、calendar、logging、argparse、re用法

datetime模块:提供日期和时间相关的功能。importdatetime#获取当前日期和时间current_time=datetime.datetime.now()#格式化日期...

python入门到脱坑正则表达式—re.search()函数

re.search()是Python正则表达式模块re中的核心函数之一,用于在字符串中搜索匹配指定模式的第一个位置。与re.match()不同,它不限制匹配必须从字符串开头开始。基本语法...

python3从零学习-5.2.1、日历相关模块calendar

源代码:Lib/calendar.py这个模块让你可以输出像Unixcal那样的日历,它还提供了其它与日历相关的实用函数。默认情况下,这些日历把星期一当作一周的第一天,星期天为一周的最后一...

DAY6-step7 Python 示例说明CALENDAR

Python中的Calendar模块具有Calendar类,该类允许基于日期,月份和年份来计算各种任务。最重要的是,Python中的TextCalendar和HTMLCalendar类允许您编辑日历...

Python 数据分析——Pandas 时间序列

Pandas提供了表示时间点、时间段和时间间隔等三种与时间有关的类型,以及元素为这些类型的索引对象,并提供了许多时间序列相关的函数。一、时间点、时间段、时间间隔Timestamp对象从Python标准...

取消回复欢迎 发表评论: