美文网首页
02_JSON数据

02_JSON数据

作者: 雨点的光辉 | 来源:发表于2024-04-17 13:39 被阅读0次

一、定义

  • 是一种数据格式
  • 使用JavaScript对象表示法

二、结构

1. 对象结构

json格式的数据,在python中是以字符串或者字节类型来呈现

{
    "code": 0,
    "msg": "OK",
    "data": {
        "id": 7,
        "member_id": 60,
        "title": true,
        "amount": 400.0,
        "full_time": null
    }
}

2. 数组结构

[{
    "id": 7,
    "member_id": 60,
    "title": true,
    "amount": 400.0,
    "full_time": null
}, {
    "name": "merrill",
    "age": "24"
}]

3. 注意事项

  • json格式的数据,在python中以字符串形式呈现
  • json中空值为null,布尔值(True和False)都要以小写开头(true和false)
  • json中除数字、null、true和false外,所有的key和value都是字符串,且一定只能使用双引号

三、使用JSON数据

1. 使用对象结构的JSON数据

1.1 将json格式的字符串转换python中的数据类型(转换为字典)

  • 导入json模块,使用loads方法
import json

data_json = '{"code": 0,"msg": "OK","data": [{"id": 7, "member_id": 60, "title": true, "amount": 400.0, "full_time": null}]}'

# 将json格式的字符串转换python中的数据类型(转换为字典或者嵌套字典的列表)
data_dict = json.loads(data_json)
print(data_dict)
print(type(data_dict))

输出结果如下:

{'code': 0, 'msg': 'OK', 'data': [{'id': 7, 'member_id': 60, 'title': True, 'amount': 400.0, 'full_time': None}]}
<class 'dict'>

注意:函数json.loads是不能使用单引号引用的json字符串,可改用双引号,或者在json.loads之前先调用json.dumps(数据)

1.2 将python中的字典或者嵌套字典的列表转换为json格式的数据

  • 导入json模块,使用dumps方法
import json

dic = {
    "name": "meriill",
    "age": "24",
    "sex": "男",
    "result": True
}

lis = [
    {
        "id": 7,
        "member_id": 60,
        "title": True,
        "amount": 400.0,
        "full_time": None
    },
    {
        "name": "merrill",
        "age": "24"
    }
]

# 如果要转换的数据中包含中文,给ensure_ascii赋值False就可以转换后显示中文
data_json_str = json.dumps(dic, ensure_ascii=False)
print(data_json_str)
print(type(data_json_str))

data_json_str_sec = json.dumps(lis)
print(data_json_str_sec)
print(type(data_json_str_sec))

输出结果如下:

{"name": "meriill", "age": "24", "sex": "男", "result": true}
<class 'str'>
[{"id": 7, "member_id": 60, "title": true, "amount": 400.0, "full_time": null}, {"name": "merrill", "age": "24"}]
<class 'str'>

2. 使用数组结构的JSON数据

2.1 将json格式的字符串转换python中的数据类型(转换为嵌套字典的列表)

  • 导入json模块,使用loads方法
import json

data_json_thr = '[{"id": 7, "member_id": 60, "title": true, "amount": 400.0, "full_time": null},{"name":"merrill","age":"24"}]'
data_list = json.loads(data_json_thr)
print(data_list)
print(type(data_list))

输出结果如下:

[{'id': 7, 'member_id': 60, 'title': True, 'amount': 400.0, 'full_time': None}, {'name': 'merrill', 'age': '24'}]
<class 'list'>

四、在配置文件中使用JSON数据

  • 导入json模块,使用load、dump方法
import json

# 从配置文件读取json类型的数据
# 在py文件中把json类型数据转换字典或者嵌套字典的列表,使用loads。
# 在配置文件中把json类型数据转换字典或者嵌套字典的列表,使用load。
with open("json.txt", encoding="utf-8") as file:
    data_dic = json.load(file)
    print(data_dic)
    print(type(data_dic))

# 把json类型的数据写入配置文件
# 在py文件中把字典或者嵌套字典的列表转换为json类型数据,使用dumps。
# 把字典或者嵌套字典的列表转换为json类型数据后写入到配置文件中,使用dump。
dic = {
    "name": "meriill",
    "age": "24",
    "sex": "男",
    "result": True
}

with open("json_write.txt", "w", encoding="utf-8") as file_sec:
    json.dump(dic, file_sec, ensure_ascii=False)

1. 注意事项

  • py文件中把json类型数据转换字典或者嵌套字典的列表,使用loads
  • 配置文件中把json类型数据转换字典或者嵌套字典的列表,使用load
  • py文件中把字典或者嵌套字典的列表转换为json类型数据,使用dumps
  • 把字典或者嵌套字典的列表转换为json类型数据后写入到配置文件中,使用dump

相关文章

  • 数据,数据

    谁的数据? 是个手机应用就想读取位置信息、通讯录,是个网站就想记录用户的浏览行为,他们保存了很多的数据。可是,这些...

  • 数据数据

    帖子来自:大数据社区|大数据学习交流社区|大数据免费学习资源_大数据巴士 头像 柠檬学院大数据 LV1 2016-...

  • 数据数据

    似懂非懂的好像又悟出来一个道理,居然对重来不愿意进脑袋的“数据”一词有了一面之交的熟悉呢。 自小到大就爱说些别人不...

  • Python Pandas Dataframe 的基本操作

    数据洞察 数据清洗 数据预处理 数据获取 数据筛选 6.数据汇总 数据输出

  • 《Python数据分析与挖掘实战》第四章 数据预处理

    主要包括数据清洗、数据集成、数据变幻和数据规约。 数据清洗 删除原始数据集中的无关数据、重复数据,平滑噪声数据,筛...

  • 基础定义

    一、数据结构 1.1 定义 数据项——>数据元素——>数据对象——>数据 数据对象+结构——>数据结构 数据结构包...

  • pandas手册

    导入数据 导出数据 查看、检查数据 数据选取 数据清理 数据处理:Filter、Sort和GroupBy 数据合并...

  • 2019-07-25

    数据管理 元数据是关于数据的数据 元数据打通了源数据、数据仓库、数据应用,记录了数据从产生到消费的全过程。 元数据...

  • 日志定位

    前后端 前端: 收集数据、数据校验、数据处理、数据解析、数据展现 后端: 数据解析、数据校验、数据处理 日志定位 ...

  • reshape2数据汇总

    dcast:长数据变短数据,数据变形,汇总 长数据 由1式,得到短数据: melt:短数据变长数据 短数据: 由式...

网友评论

      本文标题:02_JSON数据

      本文链接:https://www.haomeiwen.com/subject/krzigctx.html