Python學(xué)習(xí)筆記之json模塊和pickle模塊
json模塊
json用于不同語(yǔ)言之間的數(shù)據(jù)交換,比如C和Python之間等等,即可跨語(yǔ)言。而pickle只能用于python與python之間數(shù)據(jù)交換。
序列化與反序列化
我們把對(duì)象(變量)從內(nèi)存中變成可存儲(chǔ)或傳輸?shù)倪^(guò)程稱之為序列化,在Python中叫pickling,在其他語(yǔ)言中也被稱之為serialization,marshalling,flattening等等,都是一個(gè)意思。序列化之后,就可以把序列化后的內(nèi)容寫入磁盤,或者通過(guò)網(wǎng)絡(luò)傳輸?shù)絼e的機(jī)器上。反過(guò)來(lái),把變量?jī)?nèi)容從序列化的對(duì)象重新讀到內(nèi)存里稱之為反序列化,即unpickling。
如果我們要在不同的編程語(yǔ)言之間傳遞對(duì)象,就必須把對(duì)象序列化為標(biāo)準(zhǔn)格式,比如XML,但更好的方法是序列化為JSON,因?yàn)镴SON表示出來(lái)就是一個(gè)字符串,可以被所有語(yǔ)言讀取,也可以方便地存儲(chǔ)到磁盤或者通過(guò)網(wǎng)絡(luò)傳輸。JSON不僅是標(biāo)準(zhǔn)格式,并且比XML更快,而且可以直接在Web頁(yè)面中讀取,非常方便。
JSON表示的對(duì)象就是標(biāo)準(zhǔn)的JavaScript語(yǔ)言的對(duì)象,JSON和Python內(nèi)置的數(shù)據(jù)類型對(duì)應(yīng)如下:
在文件中寫入讀取數(shù)據(jù)-字典
dic =' {‘string1':'hello'}' #寫文件只能寫入字符串 - 手動(dòng)把字典變成字符串 f = open(‘hello', ‘w') f.write(dic)
f_read = open(‘hello', ‘r') data = f_read.read() #從文件中讀出的都是字符串 data = eval(data) #提取出字符串中的字典 print(data[‘name'])
json實(shí)現(xiàn)上述功能 - json可以在任意語(yǔ)言中傳送數(shù)據(jù)
dic = {‘string1':'hello'} data = json.dumps(dic) print(data) print(type(data)) #dumps()會(huì)把我們的變量變成一個(gè)json字符串 f = open(“new_hello”, “w”) f.write(data)
json字符串和我們手動(dòng)加 ’’ 變成的字符串是有區(qū)別的,它遵循json字符串規(guī)范,即字符串用雙引號(hào)引起來(lái)。
dumps會(huì)把我們傳入的任何數(shù)據(jù)類型變成雙引號(hào)引起來(lái)的字符串
# {‘string1':'hello'} ---> “{“string1”:”hello”}” # 8 ---> “8” # ‘hello' ---> ““hello”” – 被json包裝后的數(shù)據(jù)內(nèi)部只能有雙引號(hào) #[1, 2] ---> “[1, 2]”
我們?cè)诖鎯?chǔ)或傳輸?shù)臅r(shí)候把數(shù)據(jù)轉(zhuǎn)換成json字符串,可以實(shí)現(xiàn)任何語(yǔ)言通用
f_read = open(“new_hello”, “r”) data = json.loads(f_read.read()) #這個(gè)data直接就是字典類型 print(data) print(type(data))
json模塊中的方法
json.dumps() # 把數(shù)據(jù)包裝成json字符串 – 序列化 json.loads() # 從json字符串中提取出原來(lái)的數(shù)據(jù) – 反序列化
我們?cè)趐ython中將一個(gè)列表 l = [1, 2, 3] 包裝成一個(gè)json字符串并存儲(chǔ)或發(fā)送出去,假如我們?cè)贑語(yǔ)言中使用json解析,就會(huì)得到C語(yǔ)言中對(duì)應(yīng)的數(shù)據(jù)結(jié)構(gòu),提取出來(lái)就是一個(gè)數(shù)組buf[3] = {1, 2, 3}。
并不是說(shuō)dumps和loads必須要一塊用,只要是符合json規(guī)范的json字符串都可以用loads處理提取數(shù)據(jù)結(jié)構(gòu),和用不用dumps沒(méi)關(guān)系。
json.dump(data, f) #轉(zhuǎn)換成json字符串并寫入文件 #相當(dāng)于 data = json.dumps(dic) + f.write(data) data = json.load(f) #先讀取文件,再提取出數(shù)據(jù) #相當(dāng)于data = json.loads(f_read.read())
示例:
#----------------------------序列化 import json dic={'name':'alvin','age':23,'sex':'male'} print(type(dic))#<class 'dict'> j=json.dumps(dic) print(type(j))#<class 'str'> f=open('序列化對(duì)象','w') f.write(j) #-------------------等價(jià)于json.dump(dic,f) f.close()
#-----------------------------反序列化<br> import json f=open('序列化對(duì)象') data=json.loads(f.read())# 等價(jià)于data=json.load(f)
注意:
import json #dct="{'1':111}"#json 不認(rèn)單引號(hào) #dct=str({"1":111})#報(bào)錯(cuò),因?yàn)樯傻臄?shù)據(jù)還是單引號(hào):{'one': 1} dct='{"1":"111"}' print(json.loads(dct))
無(wú)論數(shù)據(jù)是怎樣創(chuàng)建的,只要滿足json格式,就可以json.loads出來(lái),不一定非要dumps的數(shù)據(jù)才能loads。
pickle模塊
Pickle的問(wèn)題和所有其他編程語(yǔ)言特有的序列化問(wèn)題一樣,就是它只能用于Python,并且可能不同版本的Python彼此都不兼容,因此,只能用Pickle保存那些不重要的數(shù)據(jù),不能成功地反序列化也沒(méi)關(guān)系。
##----------------------------序列化 import pickle dic={'name':'alvin','age':23,'sex':'male'} print(type(dic))#<class 'dict'> j=pickle.dumps(dic) print(type(j))#<class 'bytes'> f=open('序列化對(duì)象_pickle','wb')#注意是w是寫入str,wb是寫入bytes,j是'bytes' f.write(j) #-------------------等價(jià)于pickle.dump(dic,f) f.close()
#-------------------------反序列化 import pickle f=open('序列化對(duì)象_pickle','rb') data=pickle.loads(f.read())# 等價(jià)于data=pickle.load(f) print(data['age'])
pickle和json的用法是一樣的,二者學(xué)名都叫序列化,只不過(guò)json序列化之后的結(jié)果是字符串,pickle序列化后的結(jié)果是字節(jié)bytes。也就是說(shuō)形式不同,內(nèi)容是一樣的,但是,pickle序列化后的是bytes,也就是要寫入文件的數(shù)據(jù)是bytes,所以open打開(kāi)文件的時(shí)候要以wb的形式二進(jìn)制打開(kāi)。pickle寫入文件的內(nèi)容是不可讀的(亂七八糟的字符,但是計(jì)算機(jī)可以識(shí)別),json寫入的數(shù)據(jù)是可讀的。
pickle支持的數(shù)據(jù)類型更多,pickle可以序列化函數(shù)和類。雖然json不支持這兩種序列化,但是大部分場(chǎng)景還是用json。
總結(jié)
到此這篇關(guān)于Python學(xué)習(xí)筆記之json模塊和pickle模塊的文章就介紹到這了,更多相關(guān)json模塊和pickle模塊內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python編程簡(jiǎn)單幾行代碼實(shí)現(xiàn)視頻轉(zhuǎn)換Gif示例
這篇文章主要為大家介紹了簡(jiǎn)單使用幾行python代碼就可以實(shí)現(xiàn)將視頻轉(zhuǎn)換Gif的示例過(guò)程,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10python使用pyhook監(jiān)控鍵盤并實(shí)現(xiàn)切換歌曲的功能
這篇文章主要介紹了python使用pyhook監(jiān)控鍵盤并實(shí)現(xiàn)切換歌曲的功能,非??犰诺囊粋€(gè)小程序,可以讓你在游戲時(shí)避免切出游戲直接換歌,需要的朋友可以參考下2014-07-07云原生Docker部署Django和mysql項(xiàng)目全過(guò)程
最近在學(xué)習(xí)用docker部署Django項(xiàng)目,經(jīng)過(guò)百折不撓的鼓搗,終于將項(xiàng)目部署成功,下面這篇文章主要給大家介紹了關(guān)于云原生Docker部署Django和mysql項(xiàng)目的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法分析
這篇文章主要介紹了Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法,簡(jiǎn)單講述了psutil模塊的功能、原理并結(jié)合具體實(shí)例形式分析了Python使用psutil模塊針對(duì)CPU、內(nèi)存、磁盤、網(wǎng)絡(luò)等信息的讀取相關(guān)操作技巧,需要的朋友可以參考下2018-05-05python轉(zhuǎn)換wrf輸出的數(shù)據(jù)為網(wǎng)頁(yè)可視化json格式
這篇文章主要介紹了python轉(zhuǎn)換wrf輸出的數(shù)據(jù)為網(wǎng)頁(yè)可視化json格式,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09關(guān)于PyQt5中QtGui.QImage圖片顯示問(wèn)題解析
PyQt作為Qt語(yǔ)言的Python擴(kuò)展,可以用來(lái)方便快速的開(kāi)發(fā)界面應(yīng)用,本文重點(diǎn)給大家介紹PyQt5中的QtGui.QImage圖片顯示問(wèn)題分析,需要的朋友可以參考下2022-03-03Pycharm+Scrapy安裝并且初始化項(xiàng)目的方法
今天小編就為大家分享一篇Pycharm+Scrapy安裝并且初始化項(xiàng)目的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01