Python内置json实现数据本地持久化详解

 更新时间:2025年03月05日 10:00:52   作者:静香还需努力  
这篇文章主要为大家详细介绍了Python如何通过内置json实现数据本地持久化,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

四个json函数

函数
json.load()将本地json数据文件读取出来,并以列表形式返回从文件对象中读取 JSON 格式的字符串,并将其反序列化为 Python 对象
json.loads()将 JSON 格式的字符串反序列化为 Python 对象
json.dump()将 Python 对象序列化为 JSON 格式的字符串,并将其写入文件对象。
json.dumps()将 Python 对象序列化为 JSON 格式的字符串

将数据以json文件保存在本地的方式

使用file.open()

实例数据

class Person:
    name = None
    age = None
    def __init__(self, name, age):
        self.name = name
        self.age = age

person1 = Person("Alice", 30)
person2 = Person("Bob", 25)
person3 = Person("Charlie", 35)
person4 = Person("David", 28)
person5 = Person("Eve", 32)

persons = [person1, person2, person3, person4, person5]
person_list = [person.__dict__ for person in persons]
print(person_list)

'''
[{'name': 'Alice', 'age': 30}, {'name': 'Bob', 'age': 25}, {'name': 'Charlie', 'age': 35}, {'name': 'David', 'age': 28}, {'name': 'Eve', 'age': 32}]
<class 'list'>

返回的是一个列表
'''

object.__dict__

object.__dict__ 是 Python 中的一个特殊属性,用于存储对象的实例属性。每个 Python 对象都有一个 __dict__ 属性,它是一个字典,包含了对象的所有实例属性及其对应的值

将对象的数据保存到json中,需要先使用对象.__dict__将每一个对象的字典形式取出(使用列表推导式),在将每一个对象的字典形式保存在列表中,将列表保存在json文件中

data_list = [person.__dict__ for person in persons] # 列表推导式

保存数据

def load_data():
    with open(data_file, 'r', encoding='utf-8') as file:
        return json.load(file)

读取数据

def save_data(persons):
    with open(data_file, 'w', encoding='utf-8') as file:
        json.dump([person.__dict__ for person in persons], file, indent=2)

注意事项

open() 函数自动创建文件:

'r' 模式(只读模式)下,如果文件不存在,会直接抛出 FileNotFoundError,不会自动创建文件。

只有使用'w'(写入模式)或 'a'(追加模式)时,如果文件不存在,才会自动创建。

实际案例:

class HouseService:
    house_list = []
    data_file = os.path.join(os.path.dirname(__file__), 'house_data.json')
    def __init__(self):
        self.load_data()
        if not self.house_list:
            house1 = House('1', 'lihua', '123456', '郑州中原区', 800, '未出租')
            house2 = House('2', 'jack', '123452', '郑州市二七区', 900, '未出租')
            self.house_list.append(house1)
            self.house_list.append(house2)
            self.save_data()

    
    # 加载房屋数据
    def load_data(self):
        try:
            with open(self.data_file, 'r', encoding='utf-8') as file:
                data = json.load(file)
                self.house_list = [House(**house) for house in data]
        except FileNotFoundError:
            self.house_list = []
    
    # 保存房屋数据
    def save_data(self):
        with open(self.data_file, 'w', encoding='utf-8') as file:
            json.dump([house.__dict__ for house in self.house_list], file, ensure_ascii=False, indent=4)

在此案例下,load_data()函数如果不采用异常捕获的话,且文件夹中并没有house_data.json文件时,系统将直接抛出异常,当捕获异常之后,并初始化数据列表,程序可以继续向下进行,来到save_data()保存数据,并自动创建json文件

所以在开发过程中,编写保存房屋数据时,注意异常捕获

追加数据

如果有新的数据需要保存,不能直接使用mode='a', 'a'模式追加写入,会导致JSON文件变成多个独立对象而不是有效数组,新追加的数据会直接保存在[]外面

[{...}, {...}]  // 原始数据
{...}           // 新追加数据(格式错误)

所以要向json文件中追加数据,需要用到一下方法:

采用读取→修改→覆盖写入的模式(而不是直接追加)

使用'w'模式保证每次写入完整的JSON数组结构

import os
import json

# 示例数据
data = {
    "name": "Alice",
    "age": 30,
    "skills": ["Python", "Docker"],
    "is_active": True
}

data_dile = os.path.join(os.path.dirname(__file__), 'person_data.json')

def save_data(data):
    with open(data_dile, 'w', encoding='utf-8') as file:
        json.dump(data, file, indent=2)

def load_data():
    with open(data_dile, 'r', encoding='utf-8') as file:
        data = json.load(file)
        return data

exist_data = load_data() # 取出现有数据
print(type(exist_data))	# <class 'list'>
exist_data.append(data)	# 想列表中追加数据
save_data(exist_data) # 保存追加过数据后的列表

到此这篇关于Python内置json实现数据本地持久化详解的文章就介绍到这了,更多相关Python数据本地持久化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 帮你快速上手Jenkins并实现自动化部署

    帮你快速上手Jenkins并实现自动化部署

    在未学习Jenkins之前,只是对Jenkins有一个比较模糊的理解,即Jenkins是一个自动化构建项目发布的工具,可以实现代码->github或者gitlab库->jenkins自动部署->访问的整体的过程,而无需人为重新打包,今天就带大家详细了解一下,帮你快速上手Jenkins,需要的朋友可以参考下
    2021-06-06
  • 如何基于pythonnet调用halcon脚本

    如何基于pythonnet调用halcon脚本

    这篇文章主要介绍了如何基于pythonnet调用halcon脚本,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

    python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

    入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存到本地Csv文件,对该公司进行财务分析,如提取近五年,营业收入,净利润数据,并且算出同比增长,通过Pandas处理、Matplotlib可视化及Streamlit部署,实现财务数据分析
    2025-08-08
  • Python爬虫实现抓取京东店铺信息及下载图片功能示例

    Python爬虫实现抓取京东店铺信息及下载图片功能示例

    这篇文章主要介绍了Python爬虫实现抓取京东店铺信息及下载图片功能,涉及Python页面请求、响应、解析等相关操作技巧,需要的朋友可以参考下
    2018-08-08
  • Python学习入门之区块链详解

    Python学习入门之区块链详解

    区块链的基础概念很简单:一个分布式数据库,存储一个不断加长的 list,list 中包含着许多有序的记录。下面这篇文章主要给大家介绍了关于Python学习入门之区块链的相关资料,文中通过示例代码介绍的非常详细,需要的朋友们下面来一起看看吧。
    2017-07-07
  • NumPy 数组拼接与分割的使用详解

    NumPy 数组拼接与分割的使用详解

    NumPy 提供了多种方法用于​​数组拼接​​和​​分割,这些操作在数据预处理、特征工程和结果整合中至关重要,下面就来详细的介绍一下NumPy 数组拼接与分割的使用,感兴趣的可以了解一下
    2026-01-01
  • 使用llama Index帮你训练pdf的示例详解

    使用llama Index帮你训练pdf的示例详解

    这篇文章主要为大家介绍了使用llama Index 帮你训练pdf,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Python分支语句与循环语句应用实例分析

    Python分支语句与循环语句应用实例分析

    这篇文章主要介绍了Python分支语句与循环语句应用,结合具体实例形式详细分析了Python分支语句与循环语句各种常见应用操作技巧与相关注意事项,需要的朋友可以参考下
    2019-05-05
  • Python中包的用法及安装

    Python中包的用法及安装

    在本篇文章里小编给大家整理的是关于Python中一些包的基本用处和安装方法,需要的朋友们可以学习参考下。
    2020-02-02
  • Django中使用AJAX的详细过程

    Django中使用AJAX的详细过程

    在项目中前后端数据相互是一种常态,下面这篇文章主要给大家介绍了关于Django中使用AJAX的详细过程,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11

最新评论