溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

序列化模塊json代碼實例詳解

發(fā)布時間:2020-09-01 05:28:04 來源:腳本之家 閱讀:181 作者:lxingchen 欄目:web開發(fā)

json 模塊

json 是一種通用的數(shù)據(jù)傳輸格式,本質(zhì)就是一個字符串

json 要求 {'key':value}

  • key必須是字符串,value只能是: 字典,列表,字符串,數(shù)字,bool值
  • 在任何語言中他的type都必須是字符串類型
  • json是所有的變成語言都公認(rèn)的一種數(shù)據(jù)類型
  • 如果是python語言要給java語言發(fā)送信息,那么就可以轉(zhuǎn)換成json格式,。java經(jīng)過一系列轉(zhuǎn)換就可以得到數(shù)據(jù)類型

json序列化(dump/dumps) 和反序列化(load/loads)

import json

dic = {'北京': {'豐臺': {}, '海淀': {}}}
print(dic)
dic_str = json.dumps(dic,ensure_ascii=False) # 序列化過程,把字典/其他數(shù)據(jù)類型轉(zhuǎn)換成字符串,
  ensure_ascii=False,如果字典中有中文,希望寫入數(shù)據(jù)中也顯示中文,就要添加參數(shù)

print(dic_str)

with open('file',mode='w',encoding='utf-8') as f:
  f.write(dic_str)
import json
lst = [1,2,3,4,56]
with open('file',mode='w',encoding='utf-8') as f:
  json.dump(lst,f)

with open('file',mode='r',encoding='utf-8') as f1:
  ret = json.load(f1)
  print(ret)

import pickle

pickle 模塊

python語言中特有的序列化模塊

import pickle
dic = {'北京':{'朝陽':'昌平'},('天津','河北'):[1,2,3]}
ret = pickle.dumps(dic)
print(ret)

str_d = pickle.loads(ret)
print(str_d)


import pickle

dic = {'北京':{'朝陽':'昌平'},('天津','河北'):[1,2,3]}
with open('file',mode='wb') as f:
  pickle.dump(dic,f)

with open('file',mode='rb') as f1:
  ret = pickle.load(f1)
  print(ret)

pickle 和 json 的區(qū)別

1.pickle 支持python中的幾乎所有數(shù)據(jù)類型,但是只能python一門語言中使用

2.json 支持所有的語言,但只支持有限的數(shù)據(jù)類型

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI