百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

23-Python-第三方库Json(python第三方库有哪些)

liuian 2025-04-11 00:59 147 浏览

1-json库的使用

`json`库是Python标准库的一部分,用于处理JSON数据。它提供了`loads`、`dumps`等方法。

安装三方库

pip install json

1-1-将JSON字符串解析为Python对象

1-1-1-语法

将JSON字符串解析为Python对象,然后可以像访问普通Python字典一样访问解析后的数据。

json.loads(json_str)

1-1-2-例子

import json

# 定义一个JSON字符串
json_str = '{"name": "张三", "age": 30, "city": "北京"}'

# 将JSON字符串解析为Python对象
data = json.loads(json_str)

# 访问解析后的数据
print(data['name'])
print(data['age'])
print(data['city'])

1-1-3-输出结果

1-2-将Python对象转换为JSON字符串

1-2-1-语法

`json.dumps`方法将Python字典转换为JSON字符串

json.dumps(pythonObj)

1-2-2-例子

import json

# 定义一个Python字典
data = {
    'name': 'John',
    'age': 30,
    'city': 'New York'
}

# 将Python对象转换为JSON字符串
json_str = json.dumps(data)

# 打印JSON字符串
print(json_str)

1-2-3-输出结果

1-3-例子

实现从json文件中读取不同省份的人口总数并显示成柱状图

1-3-1-例子01

population.json

[
    {"province": "广东省", "population": 126012510},
    {"province": "山东省", "population": 101527453},
    {"province": "河南省", "population": 98830000},
    {"province": "四川省", "population": 83674866},
    {"province": "江苏省", "population": 85054000},
    {"province": "河北省", "population": 74610235},
    {"province": "湖南省", "population": 66444864},
    {"province": "浙江省", "population": 65400000},
    {"province": "安徽省", "population": 61130000},
    {"province": "湖北省", "population": 58300000}
]

province_population_chart.py

用于封装json文件

import json
from jinja2 import Environment, FileSystemLoader
from collections import defaultdict


def read_province_population_from_json(json_file_path):
    province_population = defaultdict(int)
    try:
        with open(json_file_path, 'r', encoding='utf-8') as file:
            data = json.load(file)
            for item in data:
                province = item.get('province')
                population = item.get('population', 0)
                if province:
                    province_population[province] += population
        return province_population
    except FileNotFoundError:
        print(f"错误:未找到文件 {json_file_path}")
    except json.JSONDecodeError:
        print(f"错误:无法解析 {json_file_path} 为有效的 JSON")
    return province_population


def generate_bar_chart_html(province_population, html_output_path):
    env = Environment(loader=FileSystemLoader('.'))
    template = env.get_template('bar_chart_template.html')

    provinces = list(province_population.keys())
    populations = list(province_population.values())

    html_content = template.render(provinces=provinces, populations=populations)
    try:
        with open(html_output_path, 'w', encoding='utf-8') as file:
            file.write(html_content)
        print(f"HTML 文件已生成:{html_output_path}")
    except Exception as e:
        print(f"错误:写入 HTML 文件时出错 - {e}")


if __name__ == "__main__":
    json_file_path = 'province_population.json'
    html_output_path = 'province_population_chart.html'

    province_population = read_province_population_from_json(json_file_path)
    generate_bar_chart_html(province_population, html_output_path)
    

bar_chart_template.html





    
    
    省份人口柱状图
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>



    
    <script>
        const ctx = document.getElementById('provincePopulationChart').getContext('2d');
        const provinces = {{ provinces|tojson }};
        const populations = {{ populations|tojson }};

        new Chart(ctx, {
            type: 'bar',
            data: {
                labels: provinces,
                datasets: [{
                    label: '人口总数',
                    data: populations,
                    backgroundColor: 'rgba(75, 192, 192, 0.2)',
                    borderColor: 'rgba(75, 192, 192, 1)',
                    borderWidth: 1
                }]
            },
            options: {
                scales: {
                    y: {
                        beginAtZero: true
                    }
                }
            }
        });
    </script>



    

1-3-2-输出结果

输出结果

1-3-3-例子02

创建 MySQL 数据库表,并将 2020 年到 2025 年不同省份的人口总数以饼状图形式显示在 HTML 中

database_operations.py

import random

def create_table(mycursor):
    mycursor.execute("""
    CREATE TABLE IF NOT EXISTS population (
        id INT AUTO_INCREMENT PRIMARY KEY,
        province VARCHAR(255),
        year INT,
        population INT
    )
    """)

def insert_data(mycursor, mydb):
    provinces = ["广东", "山东", "河南", "四川", "江苏"]
    years = [2020, 2021, 2022, 2023, 2024, 2025]
    for province in provinces:
        for year in years:
            population = random.randint(10000000, 20000000)
            sql = "INSERT INTO population (province, year, population) VALUES (%s, %s, %s)"
            val = (province, year, population)
            mycursor.execute(sql, val)
    mydb.commit()

def query_data(mycursor):
    provinces = ["广东", "山东", "河南", "四川", "江苏"]
    total_population = {}
    for province in provinces:
        sql = "SELECT SUM(population) FROM population WHERE province = %s AND year BETWEEN 2020 AND 2025"
        val = (province,)
        mycursor.execute(sql, val)
        result = mycursor.fetchone()
        total_population[province] = result[0]
    return total_population
    

database_connection.py

import mysql.connector

def create_connection():
    mydb = mysql.connector.connect(
        host="localhost",
        user="your_username",
        password="your_password",
        database="your_database"
    )
    return mydb
    

chart_generator.py

import matplotlib.pyplot as plt
import os

def generate_chart(total_population):
    labels = total_population.keys()
    sizes = total_population.values()

    plt.pie(sizes, labels=labels, autopct='%1.1f%%')
    plt.axis('equal')

    if not os.path.exists('charts'):
        os.makedirs('charts')
    chart_path = 'charts/population_pie_chart.png'
    plt.savefig(chart_path)
    plt.close()
    return chart_path
    

html_generator.py

def generate_html(chart_path):
    html_content = f"""
    
    
    
        
        2020 - 2025 年不同省份人口总数饼状图
    
    
        

2020 - 2025 年不同省份人口总数饼状图

""" with open('population_chart.html', 'w', encoding='utf-8') as f: f.write(html_content)

main.py

from database_connection import create_connection
from database_operations import create_table, insert_data, query_data
from chart_generator import generate_chart
from html_generator import generate_html

# 建立数据库连接
mydb = create_connection()
mycursor = mydb.cursor()

# 创建表
create_table(mycursor)

# 插入数据
insert_data(mycursor, mydb)

# 查询数据
total_population = query_data(mycursor)

# 生成饼状图
chart_path = generate_chart(total_population)

# 生成 HTML 文件
generate_html(chart_path)

print("数据库表创建成功,数据插入成功,饼状图已保存为图片,HTML 文件已生成。")
    

相关推荐

驱动网卡(怎么从新驱动网卡)
驱动网卡(怎么从新驱动网卡)

网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...

2026-01-30 00:37 liuian

win10更新助手装系统(微软win10更新助手)

1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...

windows11专业版密钥最新(windows11专业版激活码永久)

 Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...

手机删过的软件恢复(手机删除过的软件怎么恢复)
手机删过的软件恢复(手机删除过的软件怎么恢复)

操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...

2026-01-29 23:55 liuian

一键ghost手动备份系统步骤(一键ghost 备份)

  步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。  步骤...

怎么创建局域网(怎么创建局域网打游戏)

  1、购买路由器一台。进入路由器把dhcp功能打开  2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。  3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...

精灵驱动器官方下载(精灵驱动手机版下载)

是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...

一键还原系统步骤(一键还原系统有哪些)

1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。  2、在弹出的“准备安装”窗口中,可...

电脑加速器哪个好(电脑加速器哪款好)

我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...

任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)

是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...

u盘怎么恢复文件(u盘文件恢复的方法)

开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...

系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)

1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...

剪贴板权限设置方法(剪贴板访问权限)
剪贴板权限设置方法(剪贴板访问权限)

1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...

2026-01-29 21:37 liuian

平板系统重装大师(平板重装win系统)

如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...

联想官网售后服务网点(联想官网售后服务热线)

联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...