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

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

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

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 文件已生成。")
    

相关推荐

iOS9不越狱也能用:苹果Xcode 7编译安装第三方应用教程

在苹果iOS9正式版系统中,即使你不越狱现在也可以安装一些AppStore中根本不存在的应用程序,听上去感觉有些不可思议是吧,一起来看看这到底是怎么做到的。需要准备的东西:你需要准备一台Mac、X...

Python+Appium控制 iOS 真机,滑动、输入、点击全搞定!

移动端自动化测试中,Appium+iOS测试算是门槛稍高但非常关键的一环。很多测试同学面对XCUITest+真机操作时,总觉得“设备连不上”、“控件找不到”、“滑动失败”。先看效果今天我用...

从零到一:用Cursor和Xcode打造你的iOS App!

想要开发自己的iOSApp吗?跟随我们的教程,从前期准备到App上架,一步步教你如何实现!"步骤1:开发App的前期准备"设备和软件:你需要一台Mac电脑、免费的Xcode和Curs...

苹果向开发者推送visionOS 2.5的第四个测试版

近日,苹果面向开发者正式推送了visionOS2.5的第四个Beta开发者预览版,版本号为22O5467a。开发者只需打开设备端的设置应用,在相关选项中找到“开发者测试版”开关,即可开启下...

苹果向开发者推送visionOS 2.5的第一个测试版

苹果公司近日向其注册开发者推送了visionOS2.5更新的第一个Beta测试版,版本号为22O5442g。为了安装这一测试版,开发者们只需通过VisionPro设备上的“设置”应用...

iPhone 16 Pro Max Xcode首选,iPad Pro 2024开发利器

最佳开发者适配机型榜1.iPhone16ProMax(A18Pro模拟器优化)2.iPadPro2024(M4芯片多任务)3.iPhone15Pro(Xcode调试工具)4.iP...

react native中自定义 URL Scheme并跳转到指定页面

在ReactNative中实现类似Android的自定义URLScheme(myapp://open)并跳转到指定页面,可以通过以下步骤完成。ReactNative提供了对深度链接(...

传闻暗示 iPhone 将推出桌面模式(苹果推出页面怎样才能保持推出前的状态)

最近,除了有关iOS视觉效果大幅重新设计和更像Mac的iPadOS体验的传闻外,还有一个有趣的传闻正在流传:iPhone可能会获得某种桌面模式。MajinBu上周写道,一些匿名消息人士称,...

苹果visionOS 1.3首个测试版开启推送 建议谨慎下载

【CNMO科技消息】据外媒报道,开发者现已能够下载体验visionOS1.3首个测试版,只需将其安装在VisionPro上即可。这一版本的发布紧随5月7日释出的第五个测试版之后,而在此之前,4月3...

XcodeBuildMCP 让 AI 代理能够通过标准化接口与 Xcode 项目进行交互

项目介绍XcodeBuildMCP是一个ModelContextProtocol(MCP)服务器,提供与Xcode相关的工具,以便与AI助手和其他MCP客户端集成。它旨在通过标准化接口优化开发...

每日学习“Xcode”是什么呢?(xcode是开发什么的)

Xcode是苹果公司为macOS系统量身打造的集成开发环境(IDE),专为开发苹果生态系统内的各类应用程序,其中也包括游戏。以下从特点、安装使用、在游戏开发中的应用方面详细介绍。特点全平台支持:...

升级wpsjs工具包,创建和发布wps加载项

前一段时间wpsjs工具包不能创建、调试和发布wps加载项,目前已修复,请更新到最新版。wpsjs工具包升级到最新版可以创建和发布wps加载项。执行以下命令:npmupdate-gwpsjs...

如何在 TypeScript 中使用Enum(枚举)

在TypeScript中,枚举或枚举类型是具有一组常量值的常量长度的数据结构。这些常量值中的每一个都称为枚举的成员。在设置只能是一定数量的可能值的属性或值时,枚举很有用。一个常见的例子是一副扑克...

Vue独立组件——11个最佳Vue.js日期选择器组件

介绍本文主要介绍几个Vue的时间日期选择器组件,目的在于让开发者们多一些选择,不管是从功能还是从样式,都可以选择一个适合的组件,这些组件没有绝对的好与不好,就看个人如何选择了,以下分别介绍十一个日期选...

ABP Framework 手动升级指南:从6.0.1升级到7.0.0

ABP7.0.0正式版已经发布,ABP-Framework-All-In-One项目同步升级。LeptonXLiteTheme目前还没有包含在源码解决方案中,还是以Nuget包提供,目...