python 模块二
Posted 崽崽blog
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python 模块二相关的知识,希望对你有一定的参考价值。
#################################总结#####################
pickle(重点)
把一个对象进行序列化操作
1. dumps() 把对象序列化成字节
2. loads() 把字节反序列化成对象
3. dump() 把对象序列化写入文件
4. load() 把文件中的内容反序列化成对象
json(重点中的重点)
json你可以认为是python中的字典. 有一点点的不一样
python: True, False, None
json: true, false, null
1. dumps() 把对象序列化成json
2. loads() 把json反序列化成对象
3. dump() 把对象序列化写入文件
4. load() 把文件中的内容反序列化成对象
使用json模块完成:
1. 字典-> 字符串
import json
dic={‘a‘=‘hehe‘,‘b‘=‘haha‘}
s=json.dumps(dic,ensure_ascii=False)#json处理中文问题
print(s)#把对象序列化成json
2. 字符串 -> 字典
d=json.loads(
‘{"baby": null, "hxm": false, "syy": "史杨杨"}‘
)
print(d)#把json反序列化成对象
os.makedirs(‘baby/安哥拉/特斯拉/黄晓明‘) os.mkdir("baby/安哥拉/特斯拉/lvb") # 上层文件夹必须存在 os.rmdir("baby/baobao/baby/黄晓明") # 指定文件夹删除 print(os.path.dirname(r"D:python_workspace_s18day23 内置模块02userinfo")) #获取当前的文件名 print(os.path.exists(r"D:python_workspace_s18day23 内置模块02") ) #查看当前目录是否存在 不存在为False import sys # print(sys.platform) print(sys.path) # 找模块的. 必须要记住. 模块的搜索路径 import pickle # class Elephant: def __init__(self, name, weight, height): self.name = name self.weight = weight self.height = height def tiaoxi(self): print(f"{self.name}大象特别喜欢调戏人") e = Elephant("宝宝", "185T", "175") e.tiaoxi() # 序列化 bs = pickle.dumps(e) # 把对象进行序列化 print(bs) bs = b‘x80x03c__main__ Elephant qx00)x81qx01}qx02(Xx04x00x00x00nameqx03Xx06x00x00x00xe5xaex9dxe5xaex9dqx04Xx06x00x00x00weightqx05Xx04x00x00x00185Tqx06Xx06x00x00x00heightqx07Xx03x00x00x00175qx08ub.‘ # 发序列化 dx = pickle.loads(bs) # 发序列化. 得到的是大象 dx.tiaoxi() ###########################实例二#################### e1 = Elephant("宝宝", "185T", "175") e2 = Elephant("宝贝", "120T", "120") lst = [e1, e2] pickle.dump(lst, open("大象", mode="wb")) 读 lst = pickle.load(open("大象", mode="rb")) for dx in lst: dx.tiaoxi() ######################json################33 import json dic = {"baby":None, "hxm":False, "syy":"史杨杨"} s = json.dumps(dic, ensure_ascii=False) # json处理中文的问题 print(s+‘json‘)#把对象序列化成json d = json.loads(‘{"baby": null, "hxm": false, "syy": "史杨杨"}‘) print(d[‘baby‘])#把json反序列化成对象 f = open("baby.json", mode="w", encoding="utf-8")#把对象序列化成json写入文件 json.dump({"baby":None, "hxm":False, "syy":"史杨杨"}, f, ensure_ascii=False) ##把json反序列化成对象 从文件读取 f = open("baby.json", mode="r", encoding="utf-8") obj = json.load(f) print(obj)
以上是关于python 模块二的主要内容,如果未能解决你的问题,请参考以下文章