Python解析JSON對(duì)象的全過程記錄
前言
本章節(jié)我們將為大家介紹如何使用 Python 語言來編碼和解碼 JSON 對(duì)象。
json處理模塊的主要任務(wù),是將一個(gè)JSON對(duì)象,轉(zhuǎn)換成Python數(shù)據(jù)類型數(shù)據(jù)進(jìn)行處理,或者反之,將Python數(shù)據(jù)類型數(shù)據(jù),轉(zhuǎn)換成JSON對(duì)象(字符串流),在不同的模塊或者系統(tǒng)間傳輸。
1. JSON數(shù)據(jù)格式特點(diǎn)
- 對(duì)象表示為鍵值對(duì)
- 數(shù)據(jù)由逗號(hào)分隔
- 花括號(hào)保存對(duì)象
- 方括號(hào)保存數(shù)組
{ "students": [ { "name":"北山啦" , "age":20 }, { "name":"張三" , "age":30 }, { "name":"里斯" , "age":17 } ] }
{'students': [{'name': '北山啦', 'age': 20}, {'name': '張三', 'age': 30}, {'name': '里斯', 'age': 17}]}
上面就是一個(gè)JSON格式數(shù)據(jù)。它開起來就像是在Python中的字典數(shù)據(jù)類型。我們可以通過json模塊將它轉(zhuǎn)換成字符串或者反過來將字符串轉(zhuǎn)換成字典數(shù)據(jù)類型。
JSON也支持各種數(shù)據(jù)類型,它的數(shù)據(jù)類型和Python各種數(shù)據(jù)類型之間的對(duì)比如下:
- object —— dict
- array —— list
- string —— str
- number —— int/float
- true/false —— True/False
- null —— None
2. 常用方法總結(jié)
在json模塊中,用于處理json的主要是四個(gè)函數(shù),分別是:
- loads():從JSON字符串中讀取數(shù)據(jù)并轉(zhuǎn)換成Python數(shù)據(jù)類型
- load():從JSON文件中讀取數(shù)據(jù)并轉(zhuǎn)換成Python數(shù)據(jù)類型
- dumps():將Python數(shù)據(jù)類型數(shù)據(jù)轉(zhuǎn)換成JSON字符串
- dump():將Python數(shù)據(jù)類型數(shù)據(jù)轉(zhuǎn)換成JSON字符串寫入到文件
3. 系列化和反系列化
從JSON數(shù)據(jù)轉(zhuǎn)換到Python數(shù)據(jù),叫反系列化(deserialization)
從Python數(shù)據(jù)轉(zhuǎn)換到JSON數(shù)據(jù),叫系列化(serialization)
3.1 系列化
系列化:將Python數(shù)據(jù)轉(zhuǎn)換成JSON字符串的方法。
下面我們先來看一個(gè)簡(jiǎn)單的例子。
import json data = { "students": [ { "name":"北山啦" , "age":20 }, { "name":"張三" , "age":30 }, { "name":"里斯" , "age":17 } ] } print(type(data)) print(data) json_str = json.dumps(data) print(type(json_str))
<class 'dict'> {'students': [{'name': '北山啦', 'age': 20}, {'name': '張三', 'age': 30}, {'name': '里斯', 'age': 17}]} <class 'str'>
上面的例子中,雖然看起來數(shù)據(jù)沒有發(fā)生變化,但其實(shí)它們的數(shù)據(jù)類型已經(jīng)發(fā)生了本質(zhì)的改變:將字典數(shù)據(jù)類型的data,轉(zhuǎn)換成了str類型,然后我們就可以將這個(gè)str類型的數(shù)據(jù)轉(zhuǎn)換成流,在網(wǎng)絡(luò)上進(jìn)行傳輸或者寫入到文件等。
import json data = { "students": [ { "name":"北山啦" , "age":20 }, { "name":"張三" , "age":30 }, { "name":"里斯" , "age":17 } ] } print(type(data)) print(data) json_str = json.dumps(data, separators=('>>','::'), indent=2) print(json_str)
<class 'dict'> {'students': [{'name': '北山啦', 'age': 20}, {'name': '張三', 'age': 30}, {'name': '里斯', 'age': 17}]} { "students"::[ { "name"::"\u5317\u5c71\u5566">> "age"::20 }>> { "name"::"\u5f20\u4e09">> "age"::30 }>> { "name"::"\u91cc\u65af">> "age"::17 } ] }
將data寫入txt文件中
import json data = { "students": [ { "name":"北山啦" , "age":20 }, { "name":"張三" , "age":30 }, { "name":"里斯" , "age":17 } ] } with open("students.txt","w") as fp: json.dump(data, fp, ensure_ascii=False) print("finish")
finish
這樣就將data寫入了students.txt,看看是不是已經(jīng)將數(shù)據(jù)寫進(jìn)去了。
3.2 反系列化
從JSON數(shù)據(jù)轉(zhuǎn)換到Python類型數(shù)據(jù),叫反系列化??梢酝ㄟ^loads()/load()這兩個(gè)方法來完成。
import json with open("students.txt") as fp: data = json.load(fp) """取出字典key為students的數(shù)據(jù), 得到一個(gè)list,再?gòu)倪@個(gè)list中取第一個(gè)數(shù)據(jù)""" print(data['students'][0])
{'name': '北山啦', 'age': 20}
parse_int參數(shù)
默認(rèn)值為None,如果指定了parse_int,用來對(duì)JSON int字符串進(jìn)行解碼,這可以用于為JSON整數(shù)使用另一種數(shù)據(jù)類型或解析器。
parse_int參數(shù),這里我們簡(jiǎn)單將其指定為float類型。
import json with open("students.txt") as fp: data = json.load(fp, parse_int = float) print(data)
{'students': [{'name': '北山啦', 'age': 20.0}, {'name': '張三', 'age': 30.0}, {'name': '里斯', 'age': 17.0}]}
可以看到,age原來是整數(shù)類型,通過parse_int已經(jīng)被轉(zhuǎn)換成了float類型。
object_hook
默認(rèn)值為None,object_hook是一個(gè)可選函數(shù),此功能可用于實(shí)現(xiàn)自定義解碼器。指定一個(gè)函數(shù),該函數(shù)負(fù)責(zé)把反序列化后的基本類型對(duì)象轉(zhuǎn)換成自定義類型的對(duì)象。
def fromJSON(dct): # 這里會(huì)對(duì)所有的字典數(shù)據(jù)類型都進(jìn)行遍歷 if isinstance(dct, dict) and 'students' in dct: return dct['students'] else: return Student(dct['name'], dct['age']) import json with open("students.txt") as fp: data = json.load(fp, object_hook=fromJSON) print(data)
[姓名: 北山啦, 年齡: 20, 姓名: 張三, 年齡: 30, 姓名: 里斯, 年齡: 17]
總結(jié)
到此這篇關(guān)于Python解析JSON對(duì)象的文章就介紹到這了,更多相關(guān)Python解析JSON對(duì)象內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python使用內(nèi)置函數(shù)setattr設(shè)置對(duì)象的屬性值
- Python List列表對(duì)象內(nèi)置方法實(shí)例詳解
- Python序列對(duì)象與String類型內(nèi)置方法詳解
- Python面向?qū)ο笾惖膬?nèi)置attr屬性示例
- python3 面向?qū)ο骭_類的內(nèi)置屬性與方法的實(shí)例代碼
- Python統(tǒng)計(jì)可散列的對(duì)象之容器Counter詳解
- Python面向?qū)ο蠓庋b繼承和多態(tài)示例講解
- python學(xué)習(xí)之可迭代對(duì)象、迭代器、生成器
- Python中對(duì)象的比較操作==和is區(qū)別詳析
- 淺談Python中的常用內(nèi)置對(duì)象
相關(guān)文章
修復(fù)Python?Pandas數(shù)據(jù)標(biāo)記錯(cuò)誤的幾種方法總結(jié)
用于分析數(shù)據(jù)的?Python?庫稱為?Pandas,在?Pandas?中讀取數(shù)據(jù)最常見的方式是通過?CSV?文件,但?CSV?文件的限制是它應(yīng)該采用特定的格式,否則在標(biāo)記數(shù)據(jù)時(shí)會(huì)拋出錯(cuò)誤,在本文中,我們將討論修復(fù)?Python?Pandas?錯(cuò)誤標(biāo)記數(shù)據(jù)的各種方法2023-10-10OpenCV特征提取與檢測(cè)之Shi-Tomasi角點(diǎn)檢測(cè)器
在角點(diǎn)檢測(cè)的世界里哈瑞斯無疑是最重要的方法之一,但Shi-Tomasi作為改進(jìn)的算法也有很大應(yīng)用場(chǎng)景,尤其是動(dòng)態(tài)跟蹤用的還比較多,這篇文章主要給大家介紹了關(guān)于OpenCV特征提取與檢測(cè)之Shi-Tomasi角點(diǎn)檢測(cè)器的相關(guān)資料,需要的朋友可以參考下2021-08-08Python元類編程實(shí)現(xiàn)一個(gè)簡(jiǎn)單的ORM
本文主要介紹了Python元類編程實(shí)現(xiàn)一個(gè)簡(jiǎn)單的ORM,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03跟老齊學(xué)Python之復(fù)習(xí)if語句
是否記得,在上一部分,有一講專門介紹if語句的:從if開始語句的征程。在學(xué)習(xí)if語句的時(shí)候,對(duì)python編程的基礎(chǔ)知識(shí)了解的還不是很多,或許沒有做什么太復(fù)雜的東西。本講要對(duì)它進(jìn)行一番復(fù)習(xí),通過復(fù)習(xí)提高一下。如果此前有的東西忘記了,建議首先回頭看看前面那講。2014-10-10三步解決python PermissionError: [WinError 5]拒絕訪問的情況
這篇文章主要介紹了三步解決python PermissionError: [WinError 5]拒絕訪問的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-04-04python實(shí)現(xiàn)中文分詞FMM算法實(shí)例
這篇文章主要介紹了python實(shí)現(xiàn)中文分詞FMM算法,實(shí)例分析了Python基于FMM算法進(jìn)行中文分詞的實(shí)現(xiàn)方法,涉及Python針對(duì)文件、字符串及正則匹配操作的相關(guān)技巧,需要的朋友可以參考下2015-07-07