Python Json與pickle模塊序列化使用介紹
用于序列化的兩個模塊
- json,用于字符串 和 python數(shù)據(jù)類型間進行轉(zhuǎn)換
- pickle,用于python特有的類型 和 python的數(shù)據(jù)類型間進行轉(zhuǎn)換
Json模塊提供了四個功能:dumps、dump、loads、load
pickle模塊提供了四個功能:dumps、dump、loads、load
json.dumps 將數(shù)據(jù)通過特殊的形式轉(zhuǎn)換為所有程序語言都認識的字符串
json.dump 將數(shù)據(jù)通過特殊的形式轉(zhuǎn)換為所有程序語言都認識的字符串,并寫入文件
pickle.dumps 將數(shù)據(jù)通過特殊的形式轉(zhuǎn)換為只有Python語言認識的字符串
pickle.dump 將數(shù)據(jù)通過特殊的形式轉(zhuǎn)換為只有Python語言認識的字符串,并寫入文件
Json序列化舉例:
json序列化
# json是所有語言中都通用的,適用于不同語言進行數(shù)據(jù)交互。
# 但json只能處理簡單的數(shù)據(jù)類型,如果要處理復雜的,可以使用pickle
# 應用場景舉例:當你使用虛擬機(或者玩游戲)時,中間你突然有點別的事情,于是要將虛擬機掛起,以便下次使用時還是現(xiàn)在的狀態(tài)。
# 于是就用到了json,json序列化將虛擬機目前的狀態(tài)(比如進行了什么操作,打開了什么文件)保存在文件中,
# 當你干完別的事,再次啟動虛擬機時,json反序列化會將文件中保存的狀態(tài)從文件中讀出來,于是你就可以繼續(xù)上次的操作了。
# dump和load配合使用可以實現(xiàn)序列化和反序列化,
# 在Python2中可以dump很多次,也可以load很多次,他們一一對應,但是其實這沒什么意義
# 但在Python3中,可以dump很多次,但是當dump多次時,load會報錯,所以記住在Python3中永遠不要dump多次
import json
info = { "name":"Alex", "age":22 }
with open('text.txt','w',encoding='utf-8') as f:
#f.write(info) #報錯,字典不能寫入文件中,字符串能寫入文件中
#f.write(str(info)) #太low了
print(type(json.dumps(info))) # <class 'str'>
#f.write( json.dumps(info) ) # 高級做法1
json.dump(info,f) # 高級做法2,同上json反序列化
import json
with open('text.txt','r',encoding='utf8') as f:
#data=json.loads(f.read())
data=json.load(f) #同上
print(data["age"])
pickle序列化舉例:
pickle序列化
pickle寫進文件中的貌似是一段亂碼,其實不然,這是pickle自己的一套語法規(guī)則,當然這也不是加密
pickle可以序列化所有的數(shù)據(jù)類型
但是pickle只能在Python中使用,別的語言不認識它
import pickle
def sayhi(name):
print("Hello ",name)
info = { "name":"Alex", "age":22, 'func':sayhi }
with open('text2.txt','wb') as f:
print(type(pickle.dumps(info))) # <class 'bytes'>
f.write( pickle.dumps(info) ) # sayhi是一個內(nèi)存地址,用json序列化就寫不到文件中,會報錯pickle反序列化
import pickle
# def sayhi(name):
# print("Hello2 ",name)
with open('text2.txt','rb') as f:
data=pickle.loads(f.read()) # 報錯
print(data)
# data["func"]('alex')
# AttributeError: Can't get attribute 'sayhi' on <module '__main__' from 'D:/python-study/s14/Day04/pickle反序列化.py'>為什么報錯呢?因為sayhi是一個內(nèi)存地址,當pickle序列化.py程序執(zhí)行完之后,這個地址就被釋放了,當然我們就找不到了。
這里只是想說明一點:pickle可以序列化所有的數(shù)據(jù)類型,不管這個數(shù)據(jù)是否可被反序列化
如果想要不報錯,可以把sayhi函數(shù)的定義拷貝過來,而且還可以執(zhí)行這個函數(shù)
只要保證函數(shù)名相同就不會報錯,函數(shù)體可以完全不一樣
json模塊的作用之一:根據(jù)字符串書寫格式,將字符串自動轉(zhuǎn)換成相應格式
import json
# Python3.x中input方法獲取到的都是字符串,相當于Python2.x中的raw_input
inp_str = input("請輸入:") # 輸入一個列表,[1,2,3]
print(type(inp_str)) # <class 'str'>
inp_str = json.loads(inp_str,encoding="UTF-8") # 根據(jù)字符串書寫格式,將字符串自動轉(zhuǎn)換成 列表類型
print(type(inp_str),inp_str[0]) # <class 'list'> 1
inp_str = input("請輸入:") # 輸入一個字典,{"name":"Rose","age":21,"sex":"F"}
# 切記,字典內(nèi)部必須是 雙引號 ?。?!單引號會報錯。
print(type(inp_str)) # <class 'str'>
inp_str = json.loads(inp_str,encoding="UTF-8") # 根據(jù)字符串書寫格式,將字符串自動轉(zhuǎn)換成 字典類型
print(type(inp_str),inp_str['name'],inp_str['age'],inp_str['sex']) # <class 'dict'> Rose 21 F到此這篇關于Python Json與pickle模塊序列化使用介紹的文章就介紹到這了,更多相關Python Json與pickle內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python實現(xiàn)的查詢mysql數(shù)據(jù)庫并通過郵件發(fā)送信息功能
這篇文章主要介紹了Python實現(xiàn)的查詢mysql數(shù)據(jù)庫并通過郵件發(fā)送信息功能,可實現(xiàn)Python針對mysql的查詢與宕機信息通過郵件發(fā)送的相關操作技巧,需要的朋友可以參考下2018-05-05
國產(chǎn)化設備鯤鵬CentOS7上源碼安裝Python3.7的過程詳解
這篇文章主要介紹了國產(chǎn)化設備鯤鵬CentOS7上源碼安裝Python3.7,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05
Python獲取命令實時輸出-原樣彩色輸出并返回輸出結(jié)果的示例
今天小編就為大家分享一篇Python獲取命令實時輸出-原樣彩色輸出并返回輸出結(jié)果的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
python實現(xiàn)比對美團接口返回數(shù)據(jù)和本地mongo數(shù)據(jù)是否一致示例
這篇文章主要介紹了python實現(xiàn)比對美團接口返回數(shù)據(jù)和本地mongo數(shù)據(jù)是否一致,涉及Python基于requests模塊的數(shù)據(jù)請求與比較運算相關操作技巧,需要的朋友可以參考下2019-08-08
python Matplotlib數(shù)據(jù)可視化(2):詳解三大容器對象與常用設置
這篇文章主要介紹了python Matplotlib三大容器對象與常用設置的相關資料,幫助大家更好的學習和使用Matplotlib庫的用法,感興趣的朋友可以了解下2020-09-09

