Python序列化之Json基础
python的序列化就是将python的基本对象转换为字符串的过程,反之则是反序列化。 序列化类型:
-> import json
import pickle 序列化定义:
序列化:对象、列表、字典都是python的基本数据类型,序列化其实就是把这些数据类型转换为字符串。
反序列化:将序列化后得到的字符串转反序列化成python的数据对象、列表、字典等类型 json的作用:
在python的基本数据类型与字符串之间进行相互转换的作用 json.dumps()函数:
将python基本数据类型转换成字符串类型,称为序列化 json.loads()函数:
将字符串形式转换成python的基本数据类型,称为反序列化 json.loads()条件:
虽然loads函数可以将字符串发序列化成python基本数据类型,但是字符串必须是
正规的python基本数据类型,不能是类似{"k1":123]这样,既不是字典,又不是列表。 requests.get('URL')
获取URL指定的资源,http://wthrcdn.etouch.cn/weather_mini?city=上海 获取上海天气的API 代码部分:
import json # 做序列化和反序列化需要用到json模块
import requests #请求URL资源,需要用到requests模块 print('\n','序列化'.center(,'-'))
dic = {'k1':'v1'}
print(dic,type(dic))
# 输出结果:{'k1': 'v1'} <class 'dict'> # json.dumps(python数据类型)就可以把数据类型转换为字符串,这个过程就是序列化
result = json.dumps(dic)
print(result,type(result))
# 输出结果:{"k1": "v1"} <class 'str'> print('\n','反序列化'.center(,'-'))
#json.loads(字符串)就可以把字符串转换成python的基本数据类型,这个过程就是反序列号
s1 = '{"k1":123}' # s1虽然看起来像字典,但它是一个字符串
dic = json.loads(s1)
print(dic,type(dic))
# 输出结果: {'k1': } <class 'dict'> print('\n','基于天气API获取python的json数据'.center(,'-'))
response = requests.get('http://wthrcdn.etouch.cn/weather_mini?city=上海')
response.encoding = 'utf-8'
print(response.text,type(response.text)) # 获取到的结果是字符串类型
# 输出结果: {"data":{"yesterday":{"date":"26日星期一"... <class 'str'> # 通过json.loads()函数将字符串结果转换为字典类型,转换成字典后对字典内对数据进行操作就方便的多了。
dic = json.loads(response.text)
print(dic,type(dic)) # json.loads()转换后的结果为python的基本数据类型,这里就是字典。
# 输出结果: {'data': {'yesterday': {'date': '26日星期一... <class 'dict'>
执行结果:
------------------序列化-------------------
{'k1': 'v1'} <class 'dict'>
{"k1": "v1"} <class 'str'> ------------------反序列化------------------
{'k1': } <class 'dict'> ---------基于天气API获取python的json数据---------
{"data":{"yesterday":{"date":"26日星期一","high":"高温 28℃","fx":"西风","low":"低温 23℃","fl":"微风","type":"雷阵雨"},"city":"上海","aqi":"","forecast":[{"date":"27日星期二","high":"高温 29℃","fengli":"微风级","low":"低温 23℃","fengxiang":"西风","type":"雷阵雨"},{"date":"28日星期三","high":"高温 28℃","fengli":"微风级","low":"低温 23℃","fengxiang":"东南风","type":"小雨"},{"date":"29日星期四","high":"高温 27℃","fengli":"微风级","low":"低温 24℃","fengxiang":"东南风","type":"中雨"},{"date":"30日星期五","high":"高温 32℃","fengli":"微风级","low":"低温 26℃","fengxiang":"东南风","type":"多云"},{"date":"1日星期六","high":"高温 32℃","fengli":"4-5级","low":"低温 26℃","fengxiang":"东南风","type":"多云"}],"ganmao":"各项气象条件适宜,无明显降温过程,发生感冒机率较低。","wendu":""},"status":,"desc":"OK"} <class 'str'> {'data': {'yesterday': {'date': '26日星期一', 'high': '高温 28℃', 'fx': '西风', 'low': '低温 23℃', 'fl': '微风', 'type': '雷阵雨'}, 'city': '上海', 'aqi': '', 'forecast': [{'date': '27日星期二', 'high': '高温 29℃', 'fengli': '微风级', 'low': '低温 23℃', 'fengxiang': '西风', 'type': '雷阵雨'}, {'date': '28日星期三', 'high': '高温 28℃', 'fengli': '微风级', 'low': '低温 23℃', 'fengxiang': '东南风', 'type': '小雨'}, {'date': '29日星期四', 'high': '高温 27℃', 'fengli': '微风级', 'low': '低温 24℃', 'fengxiang': '东南风', 'type': '中雨'}, {'date': '30日星期五', 'high': '高温 32℃', 'fengli': '微风级', 'low': '低温 26℃', 'fengxiang': '东南风', 'type': '多云'}, {'date': '1日星期六', 'high': '高温 32℃', 'fengli': '4-5级', 'low': '低温 26℃', 'fengxiang': '东南风', 'type': '多云'}], 'ganmao': '各项气象条件适宜,无明显降温过程,发生感冒机率较低。', 'wendu': ''}, 'status': , 'desc': 'OK'} <class 'dict'>
Python序列化之Json基础的更多相关文章
- Python序列化之json与pickle
1.json介绍 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Progra ...
- python序列化模块json和pickle
序列化相关 1. json 应用场景: json模块主要用于处理json格式的数据,可以将json格式的数据转化为python的字典,便于python处理,同时也可以将python的字典或列表等对象转 ...
- python 序列化之JSON和pickle详解
JSON模块 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类 ...
- python序列化和json
python 的序列化和反序列化用于内存之间的共享,包括服务器和客户端的共享,两个Python程序之间的共享,以及以字符串的形式存储到硬盘中. pyhton 的pickle 可以对Python的各种数 ...
- python序列化模块 json&&pickle&&shelve
#序列化模块 #what #什么叫序列化--将原本的字典.列表等内容转换成一个字符串的过程叫做序列化. #why #序列化的目的 ##1.以某种存储形式使自定义对象持久化 ##2.将对象从一个地方传递 ...
- Python序列化,json&pickle&shelve模块
1. 序列化说明 序列化可将非字符串的数据类型的数据进行存档,如字典.列表甚至是函数等等 反序列化,将通过序列化保存的文件内容反序列化即可得到数据原本的样子,可直接使用 2. Python中常用的序列 ...
- python序列化: json & pickle & shelve 模块
一.json & pickle & shelve 模块 json,用于字符串 和 python数据类型间进行转换pickle,用于python特有的类型 和 python的数据类型间进 ...
- python 序列化 json pickle
python的pickle模块实现了基本的数据序列和反序列化.通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储:通过pickle模块的反序列化操作,我们能够从文件 ...
- Python之数据序列化(json、pickle、shelve)
本节内容 前言 json模块 pickle模块 shelve模块 总结 一.前言 1. 现实需求 每种编程语言都有各自的数据类型,其中面向对象的编程语言还允许开发者自定义数据类型(如:自定义类),Py ...
随机推荐
- EXIST子查询
已知关系模式:S(Sno,Sname,Sclass),C(Cno,Cname,Cteacher),SC(Sno,Cno,Scgrade).其中,S为学生关系:Sno学号, Sname姓名,Sclass ...
- HDU 2896 病毒侵袭【AC自动机】
<题目链接> Problem Description 当太阳的光辉逐渐被月亮遮蔽,世界失去了光明,大地迎来最黑暗的时刻....在这样的时刻,人们却异常兴奋——我们能在有生之年看到500年一 ...
- 学机器学习,不会数据处理怎么行?—— 一、NumPy详解
最近学习强化学习和机器学习,意识到数据分析的重要性,就开始补Python的几个科学计算库,并总结到博客中.本篇博客中用到的代码在这里下载. 什么是Numpy? NumPy是Python数值计算最重要的 ...
- MongoDB--集群
为什么需要集群 为了让数据安全 高(24* 7)数据可用性 灾难恢复 无停机维护(如备份,索引重建,压实) 读缩放(额外的副本读取) 副本集对应用程序是透明 设置集群 准备工作 在MongoDB的集群 ...
- 洛谷.4897.[模板]最小割树(Dinic)
题目链接 最小割树模板.具体见:https://www.cnblogs.com/SovietPower/p/9734013.html. ISAP不知为啥T成0分了.. Dinic: //1566ms ...
- 洛谷P2242 公路维修问题
To 洛谷.2242 公路维修问题 题目描述 由于长期没有得到维修,A国的高速公路上出现了N个坑.为了尽快填补好这N个坑,A国决定对M处地段采取交通管制.为了求解方便,假设A国的高速公路只有一条,而且 ...
- Scrapy爬虫框架的安装
Scrapy框架是我在Windows中遇到的最难安装的第三方库,一直不想写这篇博客,但碰巧今天重装了系统,这正好是个机会? 1.安装pywin32:https://sourceforge.net/pr ...
- 使用TVTK库创建一个矩形视图
from tvtk.api import tvtk # s=tvtk.ConeSource(height=,radius=) # print(s.center) #创建一个长方体数据源,并同时设置长宽 ...
- Python 中的垃圾回收机制--备忘
GC作为现代编程语言的自动内存管理机制,专注于两件事:1. 找到内存中无用的垃圾资源 2. 清除这些垃圾并把内存让出来给其他对象使用.GC彻底把程序员从资源管理的重担中解放出来,让他们有更多的时间放在 ...
- Centos7安装Redis 3.2.8
关闭防火墙和SELinx 关闭防火墙 [root@node1 ~]# systemctl stop firewalld 开启防火墙 [root@node1 ~]# systemctl enable f ...