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

Python操作JSON實現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)交換

 更新時間:2022年06月22日 10:48:03   作者:? 編程學習網(wǎng)?  ?  
這篇文章主要介紹了Python操作JSON實現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)交換,JSON的全稱是 JavaScript Object Notation,是一種輕量級的數(shù)據(jù)交換格式,關(guān)于JSON的更多相關(guān)內(nèi)容感興趣的小伙伴可以參考一下

前言

學學Python中操縱JSON的知識。學完本文,你可以學到如下內(nèi)容:

  • 1、JSON是什么?
  • 2、JSON與XML的優(yōu)劣差異?
  • 3、將Python對象編碼成JSON字符串
  • 4、將JSON字符串解碼為Python對象
  • 5、解決JSON中文亂碼問題

JSON是什么?

JSON的全稱是 JavaScript Object Notation,是一種輕量級的數(shù)據(jù)交換格式。最初,JSON 只是 JavaScript 的子集,但由于其簡單易用而迅速走紅。

現(xiàn)今大部分編程語言都支持對JSON的解析與生成,而近些年異軍突起的NoSQL數(shù)據(jù)庫也多參照JSON來設(shè)計數(shù)據(jù)存儲格式,例如Mongodb的BSON(Binary JSON)。

JSON有以下六種數(shù)據(jù)類型:number、boolean、string、null、array、object。前三種很好理解,第四個null對應Python的None,最后兩種,對應Python的列表和字典。

 {
   "name": "小明",
   "age": 14,
   "gender": true,
   "grade": null,
  "skills": [
     "JavaScript",
    "Java",
     "Python"
  ]
}

JSON與XML的優(yōu)劣差異?

在JSON出現(xiàn)之前,人們用XML在網(wǎng)絡(luò)上交換數(shù)據(jù),在JSON出現(xiàn)后,它基本上就取代了XML的位置。兩者的共同之處顯而易見,它們都是結(jié)構(gòu)化的語言,都可以用于網(wǎng)絡(luò)數(shù)據(jù)的交換。

兩者最大的差異在于它們的“出身”不同,也就是它們被創(chuàng)造的目的不同。

XML是W3C(萬維網(wǎng)聯(lián)盟)發(fā)布的可擴展標記語言(Extensible Markup Language),最初設(shè)計來彌補HTML的不足,以強大的擴展性滿足網(wǎng)絡(luò)信息發(fā)布的需要,與它“同級”的有:XHTML\CSS\ECMAScript等。它包含DTD、XSD、XPath、XSL等一大堆復雜的規(guī)范,在數(shù)據(jù)存儲、擴展及高級檢索等方面都有作用。后來被用于網(wǎng)絡(luò)數(shù)據(jù)交換,頗有點大材小用的意思,雖然可勝任,卻也有點復雜和冗余。

而JSON是ECMAScript標準的子集,設(shè)計之初就是為了克服XML在數(shù)據(jù)交換上的劣勢,所以一方面,它像XML一樣具有簡潔而清晰的層次結(jié)構(gòu),另一方面,它比XML小巧精致,更加適用于網(wǎng)絡(luò)數(shù)據(jù)的傳輸。

JSON也不是沒有缺點,當結(jié)構(gòu)層級很多的時候,它會讓人陷入繁瑣復雜的數(shù)據(jù)節(jié)點查找中,在可讀性上要比XML差。

將Python對象編碼成JSON字符串

將python的對象轉(zhuǎn)化為字符串,這個過程也稱為序列化,與之相對,將JSON字符串轉(zhuǎn)化為python對象,這個過程被稱為反序列化。

序列化格式如下,json.dumps()把python對象序列化,json.dump() 先序列化,然后將內(nèi)容存入文件:

json.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)
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)
In [1]: import json
In [2]: d = dict(name='Tom', age='8', score=88)
In [3]: json.dumps(d)
Out[3]: '{"name": "Tom", "age": "8", "score": 88}'
In [4]: with open('test.json', 'w') as f:
   ...:     json.dump(d, f)

用的比較多的參數(shù)有:

  • ensure_ascii=True 設(shè)置是否編碼為ASCII,默認是,若False,則使用原編碼碼格式
  • indent=None 設(shè)置打印時縮進,默認不縮進
  • separators=None 設(shè)置分隔符,取值是(item_separator, dict_separator)元組,默認為(‘,’,’:’),這表示keys之間用“,”隔開,而key和value之間用“:”隔開
  • sort_keys=False 設(shè)置按key值排序,默認不排序

將JSON字符串解碼為Python對象

反序列化格式如下,json.loads()從內(nèi)存中讀取內(nèi)容解析,json.load() 從文件中讀取內(nèi)容解析:

json.loads(s,

, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None,

*kw)

json.load(fp,

, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None,

*kw)

In [1]: import json2In [2]: d = dict(name='Tom', age='8', score=88)
In [3]: tom_json = json.dumps(d)
In [4]: json.loads(tom_json)
Out[4]: {'age': '8', 'name': 'Tom', 'score': 88}
In [5]: with open('test.json', 'r') as f:
   ...:     print(json.load(f))
{'name': 'Tom', 'age': '8', 'score': 88}

json.loads()比json.load() 多了一個encoding參數(shù),可以將傳入的字符串重新編碼。

解決中文亂碼問題

序列化的ensure_ascii參數(shù)與反序列化的encoding相對應,都是處理字符編碼,一旦處理不好,就會導致中文亂碼問題。

Python2的字符編碼亂七八糟,也廣被人詬病,如果不幸遇到Python2項目,可參照如下例子解決。

字符串在Python2內(nèi)部的表示是unicode編碼。因此,在做編碼轉(zhuǎn)換時,需要以unicode作為中間編碼,即先將其他編碼的字符串解碼(decode)成unicode,再從unicode編碼(encode)成另一種編碼。

 # -*- coding: utf-8 -*-
 m = {'a' : '你好'}
 print m
 =>{'a': '\xe4\xbd\xa0\xe5\xa5\xbd'}
 print json.dumps(m)
 =>{"a": "\u4f60\u597d"}

print json.dumps(m,ensure_ascii=False)
=>{"a": "浣犲ソ"}
print json.dumps(m,ensure_ascii=False).decode('utf8').encode('gb2312')
=>{"a": "你好"}

Python3的默認編碼格式是utf-8,以上例子,只需要ensure_ascii=False,就能解決。

到此這篇關(guān)于Python操作JSON實現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)交換的文章就介紹到這了,更多相關(guān) Python操作JSON 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python Django框架實現(xiàn)應用添加logging日志操作示例

    Python Django框架實現(xiàn)應用添加logging日志操作示例

    這篇文章主要介紹了Python Django框架實現(xiàn)應用添加logging日志操作,結(jié)合實例形式分析了Django框架中添加Python內(nèi)建日志模塊相關(guān)操作技巧,需要的朋友可以參考下
    2019-05-05
  • Python中文件操作簡明介紹

    Python中文件操作簡明介紹

    這篇文章主要介紹了Python中文件操作簡明介紹,本文講解了打開文件、讀取方法、寫入方法、文件內(nèi)移動、文件迭代、關(guān)閉文件、截取文件等內(nèi)容,并給出了一個完整操作實例,需要的朋友可以參考下
    2015-04-04
  • Python類的用法實例淺析

    Python類的用法實例淺析

    這篇文章主要介紹了Python類的用法,以實例形式簡單分析了Python中類的定義、構(gòu)造函數(shù)及使用技巧,需要的朋友可以參考下
    2015-05-05
  • Python和Golang協(xié)程的區(qū)別

    Python和Golang協(xié)程的區(qū)別

    這篇文章主要為大家介紹了Python和Golang協(xié)程的區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • python中使用iterrows()對dataframe進行遍歷的實例

    python中使用iterrows()對dataframe進行遍歷的實例

    今天小編就為大家分享一篇python中使用iterrows()對dataframe進行遍歷的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • python 使用pandas計算累積求和的方法

    python 使用pandas計算累積求和的方法

    今天小編就為大家分享一篇python 使用pandas計算累積求和的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • Python加密與解密模塊hashlib與hmac

    Python加密與解密模塊hashlib與hmac

    這篇文章介紹了Python中的加密與解密模塊hashlib與hmac,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Python獲取二維數(shù)組的行列數(shù)的2種方法

    Python獲取二維數(shù)組的行列數(shù)的2種方法

    這篇文章主要介紹了Python獲取二維數(shù)組的行列數(shù)的2種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • pycharm如何關(guān)閉pytest

    pycharm如何關(guān)閉pytest

    這篇文章主要介紹了pycharm如何關(guān)閉pytest問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • python與sqlite3實現(xiàn)解密chrome cookie實例代碼

    python與sqlite3實現(xiàn)解密chrome cookie實例代碼

    這篇文章主要介紹了python與sqlite3實現(xiàn)解密chrome cookie實例代碼,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01

最新評論