Python中json.dumps使用教程

Python中json.dumps使用教程JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。在Python中,可以使用json.dumps()函数将Python对象转化为JSON格式的数据。

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。在Python中,可以使用json.dumps()函数将Python对象转化为JSON格式的数据。

一、json.dumps()函数的语法和参数

json.dumps()函数的语法如下:

 json.dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)

其中,参数obj必须是一个Python对象,支持的数据类型包括dict、list、tuple、str、int、float、bool和None。其他参数的含义如下:

  • skipkeys:表示是否跳过dict中的非字符串类型的key,默认为False。
  • ensure_ascii:表示是否将非ASCII字符转义,默认为True。
  • check_circular:表示是否检查循环引用,默认为True。
  • allow_nan:表示是否允许NaN、Infinity、-Infinity等特殊值,默认为True。
  • cls:表示自定义的JSONEncoder,用于将Python对象序列化为JSON格式。
  • indent:表示缩进字符数,用于美化输出。
  • separators:表示分隔符,默认为(‘,’, ‘:’)。
  • default:用于处理非序列化类型的数据,如datetime类型。
  • sort_keys:表示是否按照key的字典序排序,默认为False。
  • kw:表示其他需要传递给JSONEncoder的关键字参数。

二、使用json.dumps()函数将Python对象序列化为JSON格式

1、将Python字典序列化为JSON格式:

 import json dict_obj = {'Name': 'Alice', 'Age': 18, 'Sex': 'Female'} json_str = json.dumps(dict_obj, indent=4, sort_keys=True, ensure_ascii=False) print(json_str)

输出结果如下:

 { "Age": 18, "Name": "Alice", "Sex": "Female" }

2、将Python列表序列化为JSON格式:

 import json list_obj = ['Alice', 18, 'Female'] json_str = json.dumps(list_obj, indent=4, ensure_ascii=False) print(json_str)

输出结果如下:

 [ "Alice", 18, "Female" ]

3、将Python元组序列化为JSON格式:

 import json tuple_obj = ('Alice', 18, 'Female') json_str = json.dumps(tuple_obj, indent=4, ensure_ascii=False) print(json_str)

输出结果如下:

 [ "Alice", 18, "Female" ]

4、将Python字符串序列化为JSON格式:

 import json str_obj = 'Hello, world!' json_str = json.dumps(str_obj, indent=4, ensure_ascii=False) print(json_str)

输出结果如下:

 "Hello, world!"

5、将Python数字序列化为JSON格式:

 import json num_obj = 123 json_str = json.dumps(num_obj, indent=4) print(json_str)

输出结果如下:

 123

6、将Python布尔值序列化为JSON格式:

 import json bool_obj = True json_str = json.dumps(bool_obj, indent=4) print(json_str)

输出结果如下:

 true

7、将Python空值序列化为JSON格式:

 import json none_obj = None json_str = json.dumps(none_obj, indent=4) print(json_str)

输出结果如下:

 null

三、json.dumps()函数的常用技巧

1、使用default参数序列化自定义对象

有时候,需要将自定义对象(如datetime、Decimal等)序列化为JSON格式。可以通过自定义JSONEncoder来实现,也可以使用default参数来处理。

 import json import datetime class CustomEncoder(json.JSONEncoder): def default(self, obj): if isinstance(obj, datetime.datetime): return obj.strftime('%Y-%m-%d %H:%M:%S') elif isinstance(obj, datetime.date): return obj.strftime('%Y-%m-%d') else: return super().default(obj) dt_obj = datetime.datetime.now() json_str = json.dumps(dt_obj, indent=4, cls=CustomEncoder) print(json_str)

输出结果如下:

 "2022-06-21 09:53:22"

2、使用ensure_ascii参数序列化中文字符

当Python对象中包含了中文字符时,使用json.dumps()函数默认会将中文字符转义成Unicode编码。可以通过设置ensure_ascii参数为False来输出原始的中文字符。

 import json dict_obj = {'姓名': '小明', '年龄': 18, '性别': '男'} json_str = json.dumps(dict_obj, indent=4, ensure_ascii=False) print(json_str)

输出结果如下:

 { "姓名": "小明", "年龄": 18, "性别": "男" }

3、使用indent参数美化输出的JSON格式

为了提高JSON格式的可读性,在输出时可以通过设置indent参数来实现缩进。

 import json dict_obj = {'Name': 'Alice', 'Age': 18, 'Sex': 'Female'} json_str = json.dumps(dict_obj, indent=4) print(json_str)

输出结果如下:

 { "Name": "Alice", "Age": 18, "Sex": "Female" }

总结

本文介绍了json.dumps()函数的用法和常用技巧。通过学习本文,读者可以掌握如何使用Python中的json模块将Python对象序列化为JSON格式的数据,以及如何应对常见的序列化问题。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/20667.html

(0)
上一篇 2024-06-08
下一篇 2024-06-08

相关推荐

  • MySQL8安装教程「建议收藏」

    MySQL8安装教程「建议收藏」1、下载MySQL安装包 安装包解压之后如下: 2、初始化MySQL (1). 建立初始化的ini配置文件(my.ini) 在解压之后的文件夹中并没有my.ini文件,需要自己创建,文件内容如下: …

    2022-12-19
    145
  • Python学习之路:打造高效编程思维

    Python学习之路:打造高效编程思维作为一门高效、易用、广泛应用的编程语言,Python吸引了越来越多的开发者的关注。在学习Python的过程中,除了熟练掌握语法和基本编程知识外,还需要培养高效编程思维。本文将从多个方面介绍如何打造高效的Python编程思维。

    2024-01-23
    85
  • mysql中多表查询_数据库多表查询sql语句

    mysql中多表查询_数据库多表查询sql语句第06章 MySQL多表查询 多表查询,也称为关联查询,指两个或更多个表一起完成查询操作。 前提条件:这些一起查询的表之间是有关系的(一对一、一对多),它们之间一定是有关联字段,这个关联字段可能建立了

    2023-04-29
    130
  • [亲测有效]

    [亲测有效]You can’t access this shared folder because your organization’s security policies block unauthentic…

    2023-04-06
    152
  • Redis | 第一部分:数据结构与对象 中篇《Redis设计与实现》「终于解决」

    Redis | 第一部分:数据结构与对象 中篇《Redis设计与实现》「终于解决」(第一部分:数据结构与对象 中篇) 前言 参考资料:《Redis设计与实现 第二版》; 本篇笔记按照书里的脉络,将知识点分为四个部分。其中第一部分数据结构与对象分为上中下篇,上篇包括:SDS、链表和字

    2023-04-28
    149
  • pgadmin4复制数据库_gpops工具箱安装

    pgadmin4复制数据库_gpops工具箱安装作者:颜博 青云科技数据库研发工程师 目前从事 PostgreSQL 产品开发工作,热衷于 PostgreSQL 数据库的学习和研究 | REPMGR 简介 repmgr[1] 是一套开源工具,用于管

    2023-04-30
    155
  • 利用Python编写高效的计算机视觉算法

    利用Python编写高效的计算机视觉算法计算机视觉是一种将人类视觉机制应用于计算机中的技术,在图像和视频处理、目标检测、人脸识别、图像分割等领域得到广泛应用。为了编写高效的计算机视觉算法,我们需要对一些基本概念有清晰的认识。

    2023-12-05
    103
  • 深圳哪里可以开家用电器发票-中国-新闻网

    深圳哪里可以开家用电器发票-中国-新闻网深圳哪里可以开家用电器发票【152 * 9б 28 * 21 б9】陈生,诚、信、合、作,保、真、售、后、保、障、长、期、有、效。adb的全称为Android Debug Bridge,是Andro…

    2023-02-01
    140

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注