Python3.5 Json與pickle實(shí)現(xiàn)數(shù)據(jù)序列化與反序列化操作示例
本文實(shí)例講述了Python3.5 Json與pickle實(shí)現(xiàn)數(shù)據(jù)序列化與反序列化操作。分享給大家供大家參考,具體如下:
1、Json:不同語(yǔ)言之間進(jìn)行數(shù)據(jù)交互。
(1)JSON數(shù)據(jù)序列化:dumps()
JSON數(shù)據(jù)是一種輕量級(jí)的數(shù)據(jù)交換格式,序列化:將內(nèi)存數(shù)據(jù)對(duì)象變成字符串。
#!/usr/bin/env python # -*- coding:utf-8 -*- # Author:ZhengzhengLiu import json info = { "name":"liu", "age":25, "sex":"girl" } f = open("test.txt","w") print(json.dumps(info)) f.write(json.dumps(info)) f.close()
運(yùn)行結(jié)果如下圖:
(2)JSON數(shù)據(jù)反序列化:loads()
#!/usr/bin/env python # -*- coding:utf-8 -*- # Author:ZhengzhengLiu import json f = open("test.txt","r") data = json.loads(f.read()) print(data['age'])
運(yùn)行結(jié)果 :
25
(3)Json序列化——多次dumps;反序列化——不能實(shí)現(xiàn)多次loads
#!/usr/bin/env python # -*- coding:utf-8 -*- # Author:ZhengzhengLiu import json info = { "name":"liu", "age":32 } f = open("test.txt","w") f.write(json.dumps(info)) #序列化 info["age"]= 21 f.write(json.dumps(info)) f.close()
運(yùn)行結(jié)果:
總結(jié):Json只能處理一些簡(jiǎn)單的數(shù)據(jù)類(lèi)型,如:列表、字典。字符串等。XML正在被Json逐步取代。
Json以后使用只dumps一次,loads一次即可。
2、pickle:通過(guò)pickle模塊的序列化操作我們能夠?qū)⒊绦蛑羞\(yùn)行的對(duì)象信息保存到文件中去,永久存儲(chǔ);
通過(guò)pickle模塊的反序列化操作,我們能夠從文件中創(chuàng)建上一次程序保存的對(duì)象。
只能在Python語(yǔ)言中用,不能用于其他的語(yǔ)言。
(1)pickle數(shù)據(jù)序列化:
#!/usr/bin/env python # -*- coding:utf-8 -*- # Author:ZhengzhengLiu import pickle def sayhi(name): print("hello",name) info = { "name":"liu", "age":32, "func":sayhi } f = open("test.txt","wb") print() f.write(pickle.dumps(info)) f.close()
運(yùn)行結(jié)果如下圖:
(2)pickle數(shù)據(jù)反序列化:
#!/usr/bin/env python # -*- coding:utf-8 -*- # Author:ZhengzhengLiu import pickle def sayhi(name): print("hello",name) f = open("test.txt","rb") data = pickle.loads(f.read()) print(data["func"]("liu"))
運(yùn)行結(jié)果:
hello liu
None
PS:這里再為大家推薦幾款比較實(shí)用的json在線工具供大家參考使用:
在線JSON代碼檢驗(yàn)、檢驗(yàn)、美化、格式化工具:
http://tools.jb51.net/code/json
JSON在線格式化工具:
http://tools.jb51.net/code/jsonformat
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
在線json壓縮/轉(zhuǎn)義工具:
http://tools.jb51.net/code/json_yasuo_trans
更多Python相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Python操作json技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門(mén)與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python序列化模塊之pickle與json詳解
- Python常用標(biāo)準(zhǔn)庫(kù)詳解(pickle序列化和JSON序列化)
- Python 對(duì)象序列化與反序列化之pickle json詳細(xì)解析
- Python 解析庫(kù)json及jsonpath pickle的實(shí)現(xiàn)
- Python標(biāo)準(zhǔn)庫(kù)json模塊和pickle模塊使用詳解
- Python之?dāng)?shù)據(jù)序列化(json、pickle、shelve)詳解
- Python序列化基礎(chǔ)知識(shí)(json/pickle)
- 簡(jiǎn)單談?wù)凱ython中的json與pickle
- 詳解Python之?dāng)?shù)據(jù)序列化(json、pickle、shelve)
- Python序列化模塊JSON與Pickle
相關(guān)文章
python機(jī)器學(xué)習(xí)高數(shù)篇之函數(shù)極限與導(dǎo)數(shù)
這篇文章主要介紹了python機(jī)器學(xué)習(xí)高數(shù)篇之函數(shù)極限和導(dǎo)數(shù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08python 實(shí)現(xiàn)dict轉(zhuǎn)json并保存文件
今天小編就為大家分享一篇python 實(shí)現(xiàn)dict轉(zhuǎn)json并保存文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12Python實(shí)現(xiàn)根據(jù)Excel生成Model和數(shù)據(jù)導(dǎo)入腳本
最近遇到一個(gè)需求,有幾十個(gè)Excel,每個(gè)的字段都不一樣,然后都差不多是第一行是表頭,后面幾千上萬(wàn)的數(shù)據(jù),需要把這些Excel中的數(shù)據(jù)全都加入某個(gè)已經(jīng)上線的Django項(xiàng)目。所以我造了個(gè)自動(dòng)生成?Model和導(dǎo)入腳本的輪子,希望對(duì)大家有所幫助2022-11-11Pandas實(shí)現(xiàn)DataFrame按行求百分?jǐn)?shù)(比例數(shù))
今天小編就為大家分享一篇Pandas實(shí)現(xiàn)DataFrame按行求百分?jǐn)?shù)(比例數(shù)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12python創(chuàng)建文本文件的簡(jiǎn)單方法
在本篇內(nèi)容里小編給大家整理分享的是一篇關(guān)于python創(chuàng)建文本文件的簡(jiǎn)單方法,有需要的朋友們可以參考學(xué)習(xí)下。2020-08-08Python Zipfile模塊進(jìn)行ZIP文件的創(chuàng)建解壓信息獲取和加密等操作
這篇文章主要為大家介紹了Python Zipfile模塊進(jìn)行ZIP文件的創(chuàng)建解壓信息獲取和加密等操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01