Python学习之Json和jsonpath模块的使用

Python学习之Json模块的使用

提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加
例如:第一章 Python 机器学习入门之pandas的使用


提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

在python中,有专门处理json格式的模块——json模块,在python2.6之后的版本都自带了这一个模块,直接导入import json即可。json模块提供了四个功能:dumps、loads、dump、load,用于字符串和python数据类型之间进行转换。


一、json模块四大功能

json.dumps():将 Python 对象解码转换成 JSON 字符串
json.loads():把JSON 格式字符串解码转换成Python 对象
json.dump():将Python内置类型序列化为JSON 对象后写入文件
json.load():读取文件中JSON 形式的字符串元素转化成Python 类型

在这里插入图片描述
其中类文件对象的理解,其实就是具有read()或者write()方法的对象,比如f = open(“test.txt”,“r”) f就是类文件对象。下面对dumps和loads分别举例说明:

代码如下(示例):

import json

data = [{'a': 1, 'b': 2, 'c': 3}]
data2 = json.dumps(data)  # 将python对象转换成json字符串
print(data2)
print(type(data2))
print("-------还可以使用参数格式化输出json格式--------")
print(json.dumps(data, sort_keys=True, indent=4, separators=(',', ': ')))

jsonData = '{"a":1,"b":2,"c":3,"d":4,"e":5}'
text = json.loads(jsonData)
print("---------json转python---------")
print(text)
print(type(text))

# 返回结果如下:
# C:\software\python\python.exe D:/learn/test.py
# [{"a": 1, "b": 2, "c": 3}]
# <class 'str'>
# -------还可以使用参数格式化输出json格式--------
# [
#     {
#         "a": 1,
#         "b": 2,
#         "c": 3
#     }
# ]
# ---------json转python---------
# {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}
# <class 'dict'>
# 
# Process finished with exit code 0

​ dumps解码的过程,是把python对象转换成json对象的一个过程,常用的两个函数是dumps和dump函数。两个函数的唯一区别就是dump把python对象转换成json对象生成一个fp的文件流,而dumps则是生成了一个字符串。

​ 解码中常用的参数:

Skipkeys:默认值是False,如果dict的keys内的数据不是python的基本类型(str,unicode,int,long,float,bool,None),设置为False时,就会报TypeError的错误。此时设置成True,则会跳过这类key
ensure_ascii:默认值True,如果dict内含有non-ASCII的字符,则会类似\uXXXX的显示数据,设置成False后,就能正常显示
indent:应该是一个非负的整型,如果是0,或者为空,则一行显示数据,否则会换行且按照indent的数量显示前面的空白,这样打印出来的json数据也叫pretty-printed json
separators:分隔符,实际上是(item_separator, dict_separator)的一个元组,默认的就是(’,’,'😂;这表示dictionary内keys之间用“,”隔开,而KEY和value之间用“:”隔开
encoding:默认是UTF-8,设置json数据的编码方式
sort_keys:将数据根据keys的值进行排序。
​ python 类型向 json 类型的转化对照表如下:

Python JSON
dict object(对象)
list, tuple array(数组)
str, unicode string
int, long, float number
True true
False false
None null
​ 反之,json 类型转换到 python 的类型对照表:

JSON Python
object(对象) dict
array(数组) list
string unicode
number (int) int, long
number (real) float
true True
false False
null None
​ 🚩特别注意:转换的时候,python的None会变成null,True和False转换后首字母都会变成小写噢!他们的json格式在python中是无法被识别的,会被当成变量处理。

​ 更多的相关内容,可以查阅python的官方文档:https://docs.python.org/2/library/json.html

二、jsonpath模块

JsonPath是一种信息抽取类库,是从JSON文档中抽取指定信息的工具,提供多种语言实现版本,包括JavaScript、Python、PHP和Java。JsonPath对于JSON来说,就相当于XPATH对于XML。JsonPath结构清晰,可读性高,复杂度低,非常容易匹配,下表中对应了XPath的用法。

Xpath JSONPath 描述
/ $ 根节点
. @ 现行节点
/ . or [] 取子节点
… n/a 取父节点,Jsonpath未支持
// … 不管位置,选择所有符合条件的节点

    • 匹配所有元素节点
      @ n/a 根据属性访问,JsonPath不支持
      [] [] 迭代器(可以在里边做简单的迭代操作,如数组下标,根据内容选值等)
      | [,] 支持迭代器中做多选
      [] ?() 支持过滤操作
      n/a () 支持表达式计算
      () n/a 分组,JsonPath不支持
      pip安装:pip install jsonpath,官网文档:http://goessner.net/articles/JsonPath
      使用方法:jsonpath.jsonpath(),结果会以列表形式返回,如下请求接口返回数据提取例子
      🍊参数1:数据对象
      🍎参数2:jsonpath表达式

代码如下(示例):

import requests
import jsonpath

login_url = "http://localhost:8080/member/login"
login_data = {
    "mobile_phone": "15867554893",
    "pwd": "123456qwe",
}
header = {    "Content-Type": "application/json"}
# 发送登录的请求
response = requests.post(url=login_url, json=login_data, headers=header)
# 获取返回的json数据
json_data = response.json()

member_id = jsonpath.jsonpath(json_data, "$..id")[0]
type_token = jsonpath.jsonpath(json_data, "$..token_type")[0]
token = jsonpath.jsonpath(json_data, "$..token")[0]
print(json_data)
print("会员id:{}".format(member_id))
print("token的类型:{}".format(type_token))
print("token:{}".format(token))

运行返回的数据如下:
C:\software\python\python.exe D:/learn/test.py
{'code': 0, 'msg': 'OK', 'data': {'id': 59514, 'money': 34000.0, 'mobile_phone': '15612345678', 'reg_name': 'miki测试', 'reg_time': '2020-11-16 22:18:59.0', 'type': 0, 'token_info': {'token_type': 'Bearer', 'expires_in': '2020-12-10 00:30:01', 'token': 'eyJhbGciOiJIUzUxMiJ9.eyJtZW1iZXJfaWQiOjU5NTE0LCJleHAiOjE2MDc1MzE0MDF9.GAoCY5RZ_FWUIRMNXdURdH5y7zKuETo1qsq9Z9No9AaWvo2QGLR9maWxEY31Ddy6a7QmpT56xKg7N3YwGLTbOQ'}}}
会员id:59514
token的类型:Bearer
token:eyJhbGciOiJIUzUxMiJ9.eyJtZW1iZXJfaWQiOjU5NTE0LCJleHAiOjE2MDc1MzE0MDF9.GAoCY5RZ_FWUIRMNXdURdH5y7zKuETo1qsq9Z9No9AaWvo2QGLR9maWxEY31Ddy6a7QmpT56xKg7N3YwGLTbOQ

​ 登录接口返回的json数据格式化后的层级显示如下:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python中,我们可以使用jsonpath模块来解析JSON格式的数据。下面是一个简单的例子,展示了如何使用jsonpath来获取JSON数据中的某个字段。假设我们有以下JSON数据: ```json { "name": "John", "age": 30, "city": "New York", "pets": [ { "type": "dog", "name": "Buddy" }, { "type": "cat", "name": "Fluffy" } ] } ``` 现在,我们想要获取这个JSON数据中的`name`字段和`pets`中所有宠物的名字。 首先,我们需要导入jsonpath模块: ```python import jsonpath ``` 然后,我们可以使用jsonpath模块提供的`jsonpath()`函数来获取字段: ```python import json # 将JSON数据解析为Python字典 data = json.loads(''' { "name": "John", "age": 30, "city": "New York", "pets": [ { "type": "dog", "name": "Buddy" }, { "type": "cat", "name": "Fluffy" } ] } ''') # 使用jsonpath获取name字段和pets中所有宠物的名字 name = jsonpath.jsonpath(data, '$.name')[0] pet_names = jsonpath.jsonpath(data, '$.pets[*].name') print(name) print(pet_names) ``` 输出结果: ``` John ['Buddy', 'Fluffy'] ``` 在上面的代码中,我们首先使用`json.loads()`函数将JSON数据解析为Python字典。然后,我们使用`jsonpath()`函数来获取`name`字段和`pets`中所有宠物的名字。`jsonpath()`函数的第一个参数是要查找的JSON数据(在本例中是`data`),第二个参数是jsonpath表达式。`$`表示根节点,`.name`表示获取`name`字段,`pets[*].name`表示获取`pets`中所有宠物的名字。注意,`jsonpath()`函数返回的是一个列表,因此我们需要使用索引`[0]`来获取单个值。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值