#Auther Bob#--*--conding:utf-8 --*-- #jshon这个模块就是做序列化处理的,主要用到json模块的四种方法 #1、dumps#2、loads#3、dump#4、load #先介绍dumps方法#通过jshon的dumps的模块可以把特定的对象序列化处理为字符串# import json # l1 = [1,2,3,454]# d1 = {‘k1‘:‘v1‘}# ret = json.dumps(l1)# print(type(ret))# ret = json.dumps(d1)# print(type(ret)) # <class ‘str‘># <class ‘str‘> # l1 = ‘[1,2,3,4]‘# d1 = ‘{"k1":"v1"}‘# print(type(l1))# print(type(d1)) #在来介绍loads方法#上面的l1和d1都是字符串,但是他们的外形和list和dict一样,我们就可以通过反序列化把这2个字符串转换成list和dict,这里如果#外形不是list或者dict的形状,则不会转换成功的# ret = json.loads(l1)# print(ret,type(ret))# ret = json.loads(d1)# print(ret,type(ret)) # [1, 2, 3, 4] <class ‘list‘># {‘k1‘: ‘v1‘} <class ‘dict‘> #来做一个小练习,通过第三方模块get到http请求,然后json模块把返回的字符串结构的数据转换字典的形式,这样我们就可以#对这个字典做操作# import requests# import json## ret = requests.get(‘http://wthrcdn.etouch.cn/weather_mini?city=北京‘)# ret.encoding = ‘utf-8‘# s1 = ret.text# print(s1,type(s1)) #拿到字符串形式的数据# {"desc":"invilad-citykey","status":1002} <class ‘str‘>## d1 = json.loads(s1)# print(d1,type(d1)) #通过loads的方法,把字符串转换成字典# {‘desc‘: ‘invilad-citykey‘, ‘status‘: 1002} <class ‘dict‘> #上面的dumps和loads方法都在内存中转换,下面的dump和load的方法会多一个步骤,dump是把序列化后的字符串写到一个文件中,而#load是从一个一个文件中读取文件 #然后来介绍dump方法# import json# d1 = {‘name‘:‘foot‘}#这一步就会把d1做序列化处理后的字符串写到db这个文件中 # json.dump(d1,open(‘db‘,‘w‘))# d1 = json.load(open(‘db‘,‘r‘))# print(d1,type(d1)) # {‘name‘: ‘foot‘} <class ‘dict‘>
时间: 2024-12-08 20:57:55