《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 《Python 简易速速上手小册》第6章:Python 文件和数据持久化(2024 最新版)

29613cd8d666e2bf586e542e7f0d1b5.png

当然!让我们深入研究第 6 章的 6.1 节:“文件读写操作”。了解如何与文件进行交互、读取和写入数据是 Python 编程中的基本技能。

6.1 文件读写操作

在这一节,我们将学习如何打开、读取和写入文件。文件是计算机上存储和处理数据的重要方式之一,因此掌握文件读写操作对于处理各种任务至关重要。

6.1.1 打开文件

Python 中,使用内置的 open() 函数来打开文件。要打开文件,你需要指定文件的名称和打开模式。

# 打开文件以进行读取
with open("example.txt", "r") as file:
    content = file.read()
# 打开文件以进行写入
with open("output.txt", "w") as file:
    file.write("Hello, World!")

在上面的示例中,我们使用 open() 函数打开了两个文件。第一个示例打开了一个名为 “example.txt” 的文件以供读取(模式为"r"),而第二个示例打开了一个名为 “output.txt” 的文件以供写入(模式为"w")。使用with语句可以确保文件在使用完后被正确关闭,这是一种良好的做法,因为它可以防止资源泄漏。

6.1.2 读取文件内容

一旦打开了文件,你可以使用不同的方法来读取文件的内容。最常见的方法之一是使用read()方法。

with open("example.txt", "r") as file:
    content = file.read()

read()方法将文件的整个内容读取为一个字符串,并将其存储在变量content中。

6.1.3 写入文件内容

要将数据写入文件,你可以使用write()方法。请注意,使用写入模式(“w”)打开文件时,如果文件已存在,它将被清空并替换为新内容。

with open("output.txt", "w") as file:
    file.write("Hello, World!")

在这个示例中,我们将字符串"Hello, World!"写入了名为"output.txt"的文件中。如果文件不存在,将会创建一个新文件。

6.1.4 关闭文件

在处理完文件后,一定要关闭文件,释放资源。使用with语句可以确保文件在退出with块时自动关闭,但你也可以使用close()方法手动关闭文件。

file = open("example.txt", "r")
content = file.read()
file.close()

这是手动关闭文件的方法,但使用with语句更安全和方便。

6.1.5 异常处理

在文件读写操作中,可能会发生各种异常,如文件不存在、权限不足等。因此,在实际应用中,要使用异常处理机制来处理这些情况,以确保程序能够优雅地处理问题而不崩溃。

try:
    with open("example.txt", "r") as file:
        content = file.read()
except FileNotFoundError:
    print("文件不存在!")
except PermissionError:
    print("没有文件访问权限!")

在这个示例中,我们使用tryexcept块来捕获可能发生的异常,并提供适当的错误消息。

文件读写操作是 Python 编程中的基础之一。了解如何打开、读取和写入文件,以及如何进行异常处理,对于处理各种任务都是至关重要的。无论你是处理文本文件、日志文件还是配置文件,这些技能都将成为你编程工具箱中的重要工具。继续前进,探索 Python 编程的精彩世界吧!

当然!让我们深入研究第 6 章的 6.2 节:“处理J SON 和 CSV 文件”。这一节将帮助你了解如何处理这两种常见的数据格式。

6.2 处理 JSON 和 CSV 文件

在现实世界中,经常需要处理 JSON 和 CSV 格式的数据。JSON 通常用于配置文件和 Web API 响应,而 CSV 则用于电子表格和数据导出。了解如何处理这两种格式将为你的数据处理任务提供强大的工具。

6.2.1 读取 JSON 文件

JSON(JavaScript Object Notation)是一种常见的数据交换格式,它以易读和易写的文本形式表示数据对象。Python 内置了处理 JSON 的模块。

import json
# 从JSON文件中读取数据
with open("data.json", "r") as json_file:
    data = json.load(json_file)
# 访问JSON数据
print(data["name"])
print(data["age"])

在上面的示例中,我们使用json.load()方法从名为"data.json"的 JSON 文件中读取数据,并将其解析为 Python 字典。然后,我们可以像访问字典一样访问 JSON 数据的各个字段。

6.2.2 写入 JSON 文件

如果你想将 Python 数据结构保存为 JSON 文件,也可以使用 JSON 模块。

import json
# 创建一个Python字典
data = {"name": "Alice", "age": 30}
# 将数据写入JSON文件
with open("output.json", "w") as json_file:
    json.dump(data, json_file)

在这个示例中,我们首先创建了一个包含数据的 Python 字典,然后使用 json.dump() 方法将数据写入名为 “output.json” 的 JSON 文件中。

6.2.3 处理 CSV 文件

CSV(Comma-Separated Values)是一种常见的表格数据格式,它使用逗号或其他分隔符来分隔数据字段。Python 内置了处理 CSV 的模块。

import csv
# 从CSV文件中读取数据
with open("data.csv", "r", newline="") as csv_file:
    reader = csv.DictReader(csv_file)
    for row in reader:
        print(row["name"], row["age"])

在上面的示例中,我们使用csv.DictReader()来读取CSV文件,并将每一行数据解析为一个字典,其中列名作为字典的键。然后,我们可以轻松地访问和处理 CSV 数据。

6.2.4 写入 CSV 文件

如果你有一个包含字典的列表,可以使用CSV模块将数据写入CSV文件。

import csv
data_to_write = [{"name": "Alice", "age": 30}, {"name": "Bob", "age": 25}]
# 写入CSV文件
with open("output.csv", "w", newline="") as csv_file:
    fieldnames = ["name", "age"]
    writer = csv.DictWriter(csv_file, fieldnames=fieldnames)
    writer.writeheader()
    for row in data_to_write:
        writer.writerow(row)

在这个示例中,我们首先创建了一个包含字典的列表,然后使用csv.DictWriter()来将数据写入CSV文件。我们还使用writeheader()方法写入CSV文件的列名。

6.2.5 异常处理

在处理文件时,要注意处理可能出现的异常,例如文件不存在或格式错误。使用适当的异常处理来确保你的程序能够容忍各种情况。

处理 JSON 和 CSV 文件是 Python 编程中的常见任务,无论你是从外部数据源导入数据,还是将数据导出到其他系统,这些技能都非常有价值。继续前进,探索 Python 编程的奇妙世界,你的数据处理能力将更上一层楼!

当然,让我们深入研究第6章的6.3节:“数据库交互基础”。这一节将帮助你了解如何使用Python与MySQL数据库进行交互和编程。

6.3 数据库交互基础

数据库是用于存储和管理大量结构化数据的强大工具。Python提供了多种库和模块,可以让你与各种数据库系统进行交互,包括MySQL、SQLite、PostgreSQL等。在本节中,我们将重点介绍如何与MySQL数据库进行交互和编程。

6.3.1 连接到 MySQL 数据库

首先,我们需要使用合适的库来连接到 MySQL 数据库。在 Python 中,常用的库是mysql-connector-python,你可以使用pip来安装它:

pip install mysql-connector-python

然后,你可以使用以下代码来连接到MySQL数据库:

import mysql.connector
# 创建数据库连接
conn = mysql.connector.connect(
    host="localhost",
    user="username",
    password="password",
    database="mydatabase"
)
# 创建游标对象
cursor = conn.cursor()

在上面的示例中,我们使用mysql.connector库创建了与MySQL数据库的连接。你需要提供数据库的主机名(host)、用户名(user)、密码(password)和数据库名称(database)。然后,我们创建了一个游标对象,用于执行SQL查询和操作数据库。

6.3.2 执行 SQL 查询

一旦连接到数据库,你可以使用游标对象来执行SQL查询和操作数据。以下是一些常见的示例:

6.3.2.1 创建表格

# 创建表格
cursor.execute("CREATE TABLE IF NOT EXISTS users (id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255), age INT)")

6.3.2.2 插入数据

# 插入数据
sql = "INSERT INTO users (name, age) VALUES (%s, %s)"
values = ("Alice", 30)
cursor.execute(sql, values)
# 提交更改
conn.commit()

6.3.2.3 查询数据

# 查询数据
cursor.execute("SELECT * FROM users")
result = cursor.fetchall()
for row in result:
    print(row)

6.3.2.4 更新数据

# 更新数据
sql = "UPDATE users SET age = %s WHERE name = %s"
values = (25, "Alice")
cursor.execute(sql, values)
# 提交更改
conn.commit()

6.3.2.5 删除数据

# 删除数据
sql = "DELETE FROM users WHERE name = %s"
values = ("Alice",)
cursor.execute(sql, values)
# 提交更改
conn.commit()

这些示例演示了如何执行常见的SQL操作,包括创建表格、插入数据、查询数据、更新数据和删除数据。

6.3.3 提交更改和关闭连接

在执行SQL操作后,一定要使用commit()方法提交更改,以确保更改生效。最后,不要忘记关闭数据库连接。

# 提交更改
conn.commit()
# 关闭游标和连接
cursor.close()
conn.close()

6.3.4 异常处理

与文件操作类似,在数据库交互过程中也可能发生各种异常,例如数据库连接失败、SQL 语法错误等。因此,要使用适当的异常处理机制来处理这些情况,以确保程序能够容忍各种问题。

import mysql.connector
try:
    # 尝试连接到数据库
    conn = mysql.connector.connect(
        host="localhost",
        user="username",
        password="password",
        database="mydatabase"
    )
    # 创建游标对象
    cursor = conn.cursor()
    # 执行SQL查询
    cursor.execute("SELECT * FROM users")
    result = cursor.fetchall()
    for row in result:
        print(row)
except mysql.connector.Error as err:
    # 处理数据库连接或查询错误
    print(f"数据库错误: {err}")
finally:
    # 无论是否发生异常,都要关闭游标和连接
    if 'conn' in locals():
        conn.close()
    if 'cursor' in locals():
        cursor.close()

在上面的示例中,我们使用tryexcept块来尝试连接到数据库并执行查询。如果发生与数据库连接或查询相关的异常,它们将被捕获并处理,然后程序将继续执行。无论是否发生异常,finally块都会确保关闭数据库连接和游标,以释放资源。

这个案例演示了如何使用异常处理机制来容忍可能发生的问题,从而使程序更稳定。这对于生产环境中的数据库应用程序非常重要,因为它们需要具备高可用性和容错性。

数据库交互是 Python 编程中的重要部分,它使你能够处理和管理大量的结构化数据。无论你是构建 Web 应用程序、数据分析工具还是管理系统,与数据库交互的能力都是非常有价值的。继续前进,探索 Python 编程的奇妙世界,你将能够构建强大的数据库驱动应用程序!

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
25天前
|
数据采集 JSON 数据处理
抓取和分析JSON数据:使用Python构建数据处理管道
在大数据时代,电商网站如亚马逊、京东等成为数据采集的重要来源。本文介绍如何使用Python结合代理IP、多线程等技术,高效、隐秘地抓取并处理电商网站的JSON数据。通过爬虫代理服务,模拟真实用户行为,提升抓取效率和稳定性。示例代码展示了如何抓取亚马逊商品信息并进行解析。
抓取和分析JSON数据:使用Python构建数据处理管道
|
30天前
|
安全 Linux 数据安全/隐私保护
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
python知识点100篇系列(15)-加密python源代码为pyd文件
|
10天前
|
图形学 Python
SciPy 空间数据2
凸包(Convex Hull)是计算几何中的概念,指包含给定点集的所有凸集的交集。可以通过 `ConvexHull()` 方法创建凸包。示例代码展示了如何使用 `scipy` 库和 `matplotlib` 绘制给定点集的凸包。
19 1
|
11天前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。
|
11天前
|
数据采集 Web App开发 iOS开发
如何使用 Python 语言的正则表达式进行网页数据的爬取?
使用 Python 进行网页数据爬取的步骤包括:1. 安装必要库(requests、re、bs4);2. 发送 HTTP 请求获取网页内容;3. 使用正则表达式提取数据;4. 数据清洗和处理;5. 循环遍历多个页面。通过这些步骤,可以高效地从网页中提取所需信息。
|
12天前
|
开发者 Python
Python中__init__.py文件的作用
`__init__.py`文件在Python包管理中扮演着重要角色,通过标识目录为包、初始化包、控制导入行为、支持递归包结构以及定义包的命名空间,`__init__.py`文件为组织和管理Python代码提供了强大支持。理解并正确使用 `__init__.py`文件,可以帮助开发者更好地组织代码,提高代码的可维护性和可读性。
15 2
|
1月前
|
Linux 区块链 Python
Python实用记录(十三):python脚本打包exe文件并运行
这篇文章介绍了如何使用PyInstaller将Python脚本打包成可执行文件(exe),并提供了详细的步骤和注意事项。
51 1
Python实用记录(十三):python脚本打包exe文件并运行
|
23天前
|
数据可视化 算法 JavaScript
基于图论的时间序列数据平稳性与连通性分析:利用图形、数学和 Python 揭示时间序列数据中的隐藏模式
本文探讨了如何利用图论分析时间序列数据的平稳性和连通性。通过将时间序列数据转换为图结构,计算片段间的相似性,并构建连通图,可以揭示数据中的隐藏模式。文章介绍了平稳性的概念,提出了基于图的平稳性度量,并展示了图分区在可视化平稳性中的应用。此外,还模拟了不同平稳性和非平稳性程度的信号,分析了图度量的变化,为时间序列数据分析提供了新视角。
51 0
基于图论的时间序列数据平稳性与连通性分析:利用图形、数学和 Python 揭示时间序列数据中的隐藏模式
|
28天前
|
Java Python
> python知识点100篇系列(19)-使用python下载文件的几种方式
【10月更文挑战第7天】本文介绍了使用Python下载文件的五种方法,包括使用requests、wget、线程池、urllib3和asyncio模块。每种方法适用于不同的场景,如单文件下载、多文件并发下载等,提供了丰富的选择。
|
29天前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。