亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python中JSON的使用方法(超詳細)

 更新時間:2022年11月10日 12:22:51   作者:ZSYL  
JSON是一種輕量級的數(shù)據(jù)交換格式,它是JavaScript的子集,易于人閱讀和編寫,這篇文章主要介紹了Python中JSON的基本使用,需要的朋友可以參考下

1. JSON簡介

JSON(JavaScript Object Notation) 是一種輕量級的數(shù)據(jù)交換格式,它是JavaScript的子集,易于人閱讀和編寫。

JSON用來存儲和交換文本信息,比xml更小/更快/更易解析,易于讀寫,占用帶寬小,網(wǎng)絡(luò)傳輸速度快的特性,適用于數(shù)據(jù)量大,不要求保留原有類型的情況。。

前端和后端進行數(shù)據(jù)交互,其實就是JSPython進行數(shù)據(jù)交互!

2. JSON語法規(guī)則

  • 名稱必須用雙引號(即:" ")來包括
  • 值可以是雙引號包括的字符串、數(shù)字、true、false、null、JavaScript數(shù)組,或子對象
  • 數(shù)據(jù)在name/value
  • 數(shù)據(jù)見用逗號分隔
  • 花括號保存對象
  • 方括號保存數(shù)組

3. JSON數(shù)據(jù)類型

一并列舉出Python與JSON數(shù)據(jù)類型的映射關(guān)系:

Python

JSON
dictobject
list, tuplearray
str, unicodestring
int, long, floatnumber
Truetrue
False

false

Nonenull

4. JSON對象

在花括號中書寫,對象可以包含多個名稱/值對。

例:

{"firstname": "jonh", "lastname": "Doe"}

5. JSON數(shù)組

Employees是包含三個對象的數(shù)組。

每個對象代表一條關(guān)于某個人名的記錄,在方括號中書寫,數(shù)組可以包含多個對象:

{
	"employees": [
		{ “firstName”:“John” , “l(fā)astName”:“Doe” },
		{ “firstName”:“Anna” , “l(fā)astName”:“Smith” },
		{ “firstName”:“Peter” , “l(fā)astName”:“Jones” }
	]
}

6. JSON中常用的方法

python在使用json這個模塊前,首先要導(dǎo)入json庫:import json.

方法描述
json.dumps()將 Python 對象編碼成 JSON 字符串
json.loads()將已編碼的 JSON 字符串解碼為 Python 對象
json.dump()將Python內(nèi)置類型序列化為json對象后寫入文件
json.load()讀取文件中json形式的字符串元素轉(zhuǎn)化為Python類型

注意:不帶s的是序列化到文件或者從文件反序列化,帶s的都是內(nèi)存操作不涉及持久化。

6.1 json.dumps()

import json
 
data = {'name':'nanbei','age':18}
# 將Python對象編碼成json字符串
print(json.dumps(data))

結(jié)果:

{"name": "nanbei", "age": 18}

: 在這里我們可以看到,原先的單引號已經(jīng)變成雙引號了

6.2 json.loads()

import json
 
data = {'name':'nanbei','age':18}
# 將Python對象編碼成json字符串
# print(json.dumps(data))
# 將json字符串解碼成Python對象
a = json.dumps(data)
print(json.loads(a))

結(jié)果:

{'name': 'nanbei', 'age': 18}

在這里舉個元組和列表的例子:

import json
 
data = (1,2,3,4)
data_json = [1,2,3,4]
#將Python對象編碼成json字符串
print(json.dumps(data))
print(json.dumps(data_json))

#將Python對象編碼成json字符串
a = json.dumps(data)
b = json.dumps(data_json)
#將json字符串編碼成Python對象
print(json.loads(a))
print(json.loads(b))

結(jié)果:

[1, 2, 3, 4]
[1, 2, 3, 4]
[1, 2, 3, 4]
[1, 2, 3, 4]

可以看到,元組和列表解析出來的均是數(shù)組。

由以上輸出可以看出編碼過程中,Python中的list和tuple都被轉(zhuǎn)化成json的數(shù)組,而解碼后,json的數(shù)組最終被轉(zhuǎn)化成Python的list的,無論是原來是list還是tuple。

6.3 json.dump()

將Python內(nèi)置類型序列化為json對象后寫入文件:

import json
 
data = {
    'nanbei':'haha',
    'a':[1,2,3,4],
    'b':(1,2,3)
}
with open('json_test.txt','w+') as f:
    json.dump(data,f)

6.4 json.load()

讀取文件中json形式的字符串元素轉(zhuǎn)化為Python類型:

import json
 
data = {
    'nanbei':'haha',
    'a':[1,2,3,4],
    'b':(1,2,3)
}
with open('json_test.txt','w+') as f:
    json.dump(data,f)
 
with open('json_test.txt','r+') as f:
    print(json.load(f))

結(jié)果:

{'a': [1, 2, 3, 4], 'b': [1, 2, 3], 'nanbei': 'haha'}

6.5 更多實例

json.dumps():將一個Python數(shù)據(jù)類型列表編碼成json格式的字符串

#python的列表轉(zhuǎn)換為json的數(shù)組
>>> import json
>>> json.dumps([1,2,3])
'[1, 2, 3]'
#python的字符串轉(zhuǎn)換為json的字符串
>>> json.dumps('abdcs')
'"abdcs"'
#python的元祖轉(zhuǎn)換為json的數(shù)組
>>> json.dumps((1,2,3,'a'))
'[1, 2, 3, "a"]'#注意此時顯示的是方括號
#python的字典轉(zhuǎn)換為json的對象
>>> json.dumps({1:'a',2:'b'})
'{"1": "a", "2": "b"}'#注意此時1和2轉(zhuǎn)換后是加了引號的,因為json的名稱是必須要加引號的
#python的整數(shù)轉(zhuǎn)換為json的數(shù)字
>>> json.dumps(13)
'13'
#python的浮點數(shù)轉(zhuǎn)換為json的數(shù)字
>>> json.dumps(3.1415)
'3.1415'
#python的unicode字符串轉(zhuǎn)換為json的字符串
>>> json.dumps(u'a')
'"a"'
#python的True轉(zhuǎn)換為json的數(shù)組true
>>> json.dumps(True)
'true'
#python的False轉(zhuǎn)換為json的數(shù)組false
>>> json.dumps(False)
'false'
#python的None轉(zhuǎn)換為json的null
>>> json.dumps(None)
'null'
#json本質(zhì)上是一個字符串
>>> type(json.dumps('abc'))
<class 'str'>

dump和dumps:

import json

# dumps可以格式化所有的基本數(shù)據(jù)類型為字符串
data1 = json.dumps([])         # 列表
print(data1, type(data1))
data2 = json.dumps(2)          # 數(shù)字
print(data2, type(data2))
data3 = json.dumps('3')        # 字符串
print(data3, type(data3))
dict = {"name": "Tom", "age": 23}   # 字典
data4 = json.dumps(dict)
print(data4, type(data4))

with open("test.json", "w", encoding='utf-8') as f:
    # indent 超級好用,格式化保存字典,默認(rèn)為None,小于0為零個空格
    f.write(json.dumps(dict, indent=4))
    json.dump(dict, f, indent=4)  # 傳入文件描述符,和dumps一樣的結(jié)果

得到的輸出結(jié)果如下:格式化所有的數(shù)據(jù)類型為str類型:

[] <class 'str'>
2 <class 'str'>
"3" <class 'str'>
{"name": "Tom", "age": 23} <class 'str'>

test.json中的內(nèi)容:

{
    "name": "Tom",
    "age": 23
}

load和loads

import json

dict = '{"name": "Tom", "age": 23}'   # 將字符串還原為dict
data1 = json.loads(dict)
print(data1, type(data1))

with open("test.json", "r", encoding='utf-8') as f:
    data2 = json.loads(f.read())    # load的傳入?yún)?shù)為字符串類型
    print(data2, type(data2))
    f.seek(0)                       # 將文件游標(biāo)移動到文件開頭位置
    data3 = json.load(f)
    print(data3, type(data3))

運行結(jié)果如下:

{'name': 'Tom', 'age': 23} <class 'dict'>
{'name': 'Tom', 'age': 23} <class 'dict'>
{'name': 'Tom', 'age': 23} <class 'dict'>

7. 參數(shù)詳解

dumps(obj,skipkeys=False, ensure_ascii=True, check_circular=True,
        allow_nan=True, cls=None, indent=None, separators=None,
        default=None, sort_keys=False, **kw):

函數(shù)作用:Python對象轉(zhuǎn)變成JSON對象,便于序列化內(nèi)存/文件中。

參數(shù)

  • skipkeys: 如果為True的話,則只能是字典對象,否則會TypeError錯誤, 默認(rèn)False
  • ensure_ascii: 確定是否為ASCII編碼
  • check_circular: 循環(huán)類型檢查,如果為True的話
  • allow_nan: 確定是否為允許的值
  • indent: 會以美觀的方式來打印,呈現(xiàn),實現(xiàn)縮進
  • separators: 對象分隔符,默認(rèn)為,
  • encoding: 編碼方式,默認(rèn)為utf-8
  • sort_keys: 如果是字典對象,選擇True的話,會按照鍵的ASCII碼來排序

對于dump來說,只是多了一個fp參數(shù):

簡單說就是dump需要一個類似文件指針的參數(shù)(并不是真正的指針,可以稱之為文件對象),與文件操作相結(jié)合,即先將Python文件對象轉(zhuǎn)化為json字符串再保存在文件中。

dump(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True,
        allow_nan=True, cls=None, indent=None, separators=None,
        default=None, sort_keys=False, **kw)

Serialize ``obj`` as a JSON formatted stream to ``fp`` (a``.write()``-supporting file-like object).

類似Java中的class implements java.io.Serializable

Java提供了一種對象序列化的機制,該機制中,一個對象可以被表示為一個字節(jié)序列,該字節(jié)序列包括該對象的數(shù)據(jù)、有關(guān)對象的類型的信息和存儲在對象中數(shù)據(jù)的類型。

8. JSON反序列化為對象

JSON反序列化為類對象或者類的實例,使用的是loads()方法中的object_hook參數(shù):

代碼示例:

import json

# 定義一個員工類
class Employee(object):
      def __init__(self,name,age,sex,tel):
            self.name=name
            self.age=age
            self.sex=sex
            self.tel=tel
            
# 實例化一個對象     
emp = Employee('kongsh',18,'female',13123456789)

# 定義JSON轉(zhuǎn)換Python實例的函數(shù)
def jsonToClass(emp):
      return Employee(emp['name'], emp['age'], emp['sex'], emp['tel'])
# 定義一個json字符串(字典)
json_str = '{"name": "kongsh", "age": 18, "sex": "female", "tel": 13123456789}'

emp = json.loads(json_str, object_hook=jsonToClass)
print (emp)
print(emp.name)

結(jié)果展示:

在這里插入圖片描述

9. 常見的錯誤

9.1 讀取多行的JSON文件

假如要讀取一個多行的JSON文件:

{"坂": ["坂5742"]}
{"構(gòu)": ["構(gòu)6784"]}
{"共": ["共5171"]}
{"鉤": ["鉤94a9"]}
{"骯": ["骯80ae"]}
{"孤": ["孤5b64"]}

如果直接使用:

with open(json_path, 'r') as f:
    json_data = json.load(f)

就會報錯:拋出異常JSONDecodeError

json.decoder.JSONDecodeError: Extra data: line 2 column 1 (char 17)

表示數(shù)據(jù)錯誤,數(shù)據(jù)太多,第2行第一列

因為json只能讀取一個文檔對象,有兩個解決辦法

  • 單行讀取文件,一次讀取一行文件。
  • 保存數(shù)據(jù)源的時候,格式寫為一個對象(dump)。

1. 單行讀取文件:

with open(json_path, 'r') as f:
    for line in f.readlines():
        json_data = json.loads(line)

但是這種做法還有個問題,如果JSON文件中包含空行,還是會拋出JSONDecodeError異常。

json.decoder.JSONDecodeError: Expecting value: line 2 column 1 (char 1)

可以先處理空行,再進行文件讀取操作:

for line in f.readlines():
      line = line.strip()   # 使用strip函數(shù)去除空行
      if len(line) != 0:
          json_data = json.loads(line)

2. 合并為一個對象:

將json文件處理成一個對象文件(序列化):

{"dict": [
{"坂": ["坂5742"]},
{"構(gòu)": ["構(gòu)6784"]},
{"共": ["共5171"]},
{"鉤": ["鉤94a9"]},
{"骯": ["骯80ae"]},
{"孤": ["孤5b64"]}
]}

然后再用:

with open(json_path, 'r') as f:
     json_data = json.loads(f.read())

9.2 控制臺亂碼

# ensure_ascii=False 表示在控制臺能夠顯示中文
json_str = json.dumps(center_data_list, ensure_ascii=False)

10. 總結(jié)

  • json.dumps 將 Python 對象編碼成 JSON 字符串
  • json.loads 將已編碼的 JSON 字符串解碼為 Python 對象
  • json.dump和json.load,需要傳入文件描述符,加上文件操作。
  • json內(nèi)部的格式要注意,一個好的格式能夠方便讀取,可以用indent格式化。

個人總結(jié):

  • dump:存入的實例對象object(序列化)
  • dumps:存入的JSON的字符串?dāng)?shù)據(jù)
  • load:讀取的實例對象object(反序列化)
  • loads:讀取的JSON的字符串?dāng)?shù)據(jù),轉(zhuǎn)化為Python字典對象

參考資料:

Python中的json操作

python3基礎(chǔ):操作json

Python中JSON的基本使用

到此這篇關(guān)于Python中JSON的基本使用的文章就介紹到這了,更多相關(guān)Python JSON使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何使用python iter方法讀取文件

    如何使用python iter方法讀取文件

    iter()是Python的內(nèi)置函數(shù),用于生成迭代器,允許逐個訪問元素,節(jié)省內(nèi)存使用,iter()可以應(yīng)用于文件對象,實現(xiàn)逐行讀取,此外,iter()還可以與自定義結(jié)束標(biāo)記結(jié)合使用,適用于處理固定塊數(shù)據(jù)讀取,相較于其他文件讀取方法,iter()方法簡單高效,適合處理大文件,減少內(nèi)存占用
    2024-10-10
  • python查找重復(fù)圖片并刪除(圖片去重)

    python查找重復(fù)圖片并刪除(圖片去重)

    這篇文章主要為大家詳細介紹了python查找重復(fù)圖片并刪除,識別不同尺寸大小一致的圖片,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • 使用PyCharm創(chuàng)建Django項目及基本配置詳解

    使用PyCharm創(chuàng)建Django項目及基本配置詳解

    pycharm是個很不錯的python開發(fā)工具,大大縮短了python項目的創(chuàng)建時間以及調(diào)試時間。這篇文章主要介紹了使用PyCharm創(chuàng)建Django項目及基本配置詳解,pycharm是個很不錯的python開發(fā)工具,大大縮短了python項目的創(chuàng)建時間以及調(diào)試時間
    2018-10-10
  • 詳解Python如何生成詞云的方法

    詳解Python如何生成詞云的方法

    這篇文章主要介紹了詳解Python如何生成詞云的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • python實現(xiàn)簡單五子棋小游戲

    python實現(xiàn)簡單五子棋小游戲

    這篇文章主要為大家詳細介紹了python實現(xiàn)簡單五子棋小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Python 數(shù)據(jù)處理更容易的12個輔助函數(shù)總結(jié)

    Python 數(shù)據(jù)處理更容易的12個輔助函數(shù)總結(jié)

    Python的產(chǎn)生似乎就是專門用來處理數(shù)據(jù)的,順理成章的成為大數(shù)據(jù)的主流語言,本文介紹十二個函數(shù)輔助你更容易更便捷的用Python進行數(shù)據(jù)處理
    2021-11-11
  • python之如何復(fù)制excel模板并保留表格樣式

    python之如何復(fù)制excel模板并保留表格樣式

    這篇文章主要介紹了python之如何復(fù)制excel模板并保留表格樣式問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Python3.7中安裝openCV庫的方法

    Python3.7中安裝openCV庫的方法

    這篇文章主要介紹了Python3.7中安裝openCV庫的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07
  • 利用Python做一個電腦通知小工具

    利用Python做一個電腦通知小工具

    Windows不是有個消息通知功能,挺喜歡這個功能的,但是不太方便使用,也懶得去研究,于是準(zhǔn)備用Python自己寫一個,感興趣的可以了解一下
    2022-12-12
  • Python?dateutil庫簡化日期時間處理利器使用場景實踐

    Python?dateutil庫簡化日期時間處理利器使用場景實踐

    在Python中,處理日期和時間是常見的任務(wù)之一,dateutil庫是Python標(biāo)準(zhǔn)庫中datetime模塊的擴展,提供了許多方便的工具和函數(shù),簡化了日期和時間的操作
    2023-12-12

最新評論