0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python中三個json組件的安裝方式

馬哥Linux運維 ? 來源:博客 ? 作者:隔葉黃鶯 ? 2021-09-23 14:35 ? 次閱讀

Python 使用用 json.dumps(data) 時突然發(fā)現(xiàn)特別慢,data 本身不大,但是一個包含很多元素的列表,所以促使本人尋找一個替代的 JSON 處理庫。大概對比了一個 ujson(UtltraJSON), python-rapidjson(RapidJSON) 和 Python 自帶的 json 庫。還有一個 simplejson 是為兼容 Python 2.6 以前用的(json 是 Python 2.6 新加入的 API),性能有些差?;旧辖€是老的辣,想要收獲更好的性能,還得仰賴傳統(tǒng)的 C/C++ 語言,ujson 是用純 C 寫的,RapidJSON 是 C++ 寫的,后者還是十美分的開源產(chǎn)品。json, ujson, rapidjson 三者 loads() 方法的性能差別不太明顯,但 dumps() 大對象時 Python 自帶的 json 庫就要考驗用戶的耐心了。注:最開始本來認(rèn)定了 ujson 為最佳選擇, 所以先從 usjon 和 rapidjson 切入的,后來寫作本文的過程中,從 usjon 的自我介紹中發(fā)現(xiàn)了 Rust 寫的 orjson 很顯眼,才加入了 orjson 的測試,看來 orjson 更值得擁有。以上三個 json 組件的安裝方式分別為

pip install python-rapidjson

$ pip install simplejson

自己測試了一個 ujson 和 rapidjson 與 Python json 庫的 dumps() 的性能,simpejson 不太考慮了。測試代碼如下

# test.py

from time import timeimport sysimport string

num = int(sys.argv[1])lib = sys.argv[2]

items = []for i in range(num): items.append({c:c for c in string.ascii_letters})start = time()if lib == ‘ujson’: import ujson ujson.dumps(items)elif lib == ‘rapidjson’: import rapidjson rapidjson.dumps(items)else: import json json.dumps(items)

print(time() - start)

執(zhí)行 python 1000|10000|100000|1000000 json|ujson|rapidjson, 試結(jié)果統(tǒng)計如下(數(shù)字為不同情況下的耗時):

31709712-0fb2-11ec-8fb8-12bb97331649.png

基本上測試的性能和 Benchmark of Python JSON libraries 中的是一致的。從原文中截取了兩張圖如下:

317e661c-0fb2-11ec-8fb8-12bb97331649.png

在 UltraJSON 的 Github 項目頁面中也有對比 ujson, nujson, orjson, simplejson, json 的 Benchmarks。其中列出的 orjson(pip install orjson) 和 nujson(pip install nujson, Fork 了 UltraJSON 來支持 Numpy 序列化的) 性能表現(xiàn)上不錯,orjson 表現(xiàn)上比 ujson 還更為卓越。

看到了 orjson 后,趕緊做個對比測試,在上面的 test.py 代碼中再加上

elif lib == ‘orjson’: import orjson orjson.dumps(items)

再列出完整的對比數(shù)據(jù)

319ddc4a-0fb2-11ec-8fb8-12bb97331649.png

繼續(xù)翻看 orjson 的 Github 主頁面 ijl/orjson, 它既非用 C 也不是用 C++ 寫的,而是 Rust 語言,真是讓我眼前一亮,Rust 程序運行速度真的能與 C/C++ 相媲美的。寫到這里我要開始改變當(dāng)初只認(rèn) ujson 的主意了,orjson 或許是更佳的選擇, 本文的標(biāo)題也由最初擬定的 “Python 處理 JSON 必要時我選擇 ujson(UltraJSON)” 變成了 “Python 處理 JSON 必要時我選擇 ujson 和 orjson”。這也是寫博客時,盡可能收集更多的素材多的魅力。

補(bǔ)充一下,orjson 的 dumps() 函數(shù)使用略有不同,不再用 indent 參數(shù),并且返回值是 bytes,所以格式化成字符串的寫法如下

import orjson

json_str = orjson.dumps(record, option=orjson.OPT_INDENT_2).decode()

另外,在使用 ujson 時碰到的一個 bug 也順便記錄在此,就不立新篇了,反正現(xiàn)在找東西都不太看標(biāo)題,而是 Google 到其中的內(nèi)容。ujson 3.0.0 和 3.1.0 版本的 dumps() 的 indent 參數(shù)工作不正常,有個未關(guān)閉的 ticket ‘indent’ parameter for dumps doesn‘t indent properly in 3.0.0 #415。比如使用 ujson 3.1.0 時的現(xiàn)像是

》》》 import ujson》》》 ujson.dumps({’a‘: 1, ’b‘: 2})’{“a”:1,“b”:2}‘

》》》 ujson.dumps({’a‘: 1, ’b‘: 2}, indent=0)’{“a”:1,“b”:2}‘

》》》 ujson.dumps({’a‘: 1, ’b‘: 2}, indent=1)’{

“a”: 1,

“b”: 2

}‘

》》》 ujson.dumps({’a‘: 1, ’b‘: 2}, indent=2)’{

“a”: 1,

“b”: 2

}‘

》》》 ujson.dumps({’a‘: 1, ’b‘: 2}, indent=8)’{

“a”: 1,

“b”: 2

}‘

indent 大于 1 時都當(dāng)作 1。

換回到 ujson 2.0.3 版本時沒問題

》》》 import ujson》》》 ujson.dumps({’a‘: 1, ’b‘: 2}, indent=2)’{

“a”: 1,

“b”: 2

}‘

》》》 ujson.dumps({’a‘: 1, ’b‘: 2}, indent=8)’{

“a”: 1,

“b”: 2

}‘

在這個問題未解決之前就暫時用 pip install ujson==2.0.3 安裝 ujson 2.0.3 吧,但是這個版本無法序列化 datetime 類型。

原文鏈接:https://yanbin.blog/python-json-choose-ujson-if-necessary/

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4797

    瀏覽量

    84756
  • JSON
    +關(guān)注

    關(guān)注

    0

    文章

    119

    瀏覽量

    6978

原文標(biāo)題:Python 處理 JSON 我選擇 ujson 和 orjson

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    霍爾傳感器在相直流無刷電機(jī)中的安裝使用

    相直流無刷電機(jī)中,通常會使用三個霍爾傳感器來檢測轉(zhuǎn)子的位置,這三個霍爾傳感器的安裝通常有兩種方式:120度電角度
    的頭像 發(fā)表于 12-09 15:20 ?392次閱讀
    霍爾傳感器在<b class='flag-5'>三</b>相直流無刷電機(jī)中的<b class='flag-5'>安裝</b>使用

    在4片ADS127L11使用菊花鏈方式連接時,DRDY,START,RESET,每一片子的這三個管腳怎么接?

    在4片ADS127L11使用菊花鏈方式連接時候。DRDY,START,RESET,每一片子的這三個管腳怎么接?是分別都接mcu還是只用第一的ADS127L11的這
    發(fā)表于 11-20 07:54

    可調(diào)電阻三個腳怎么接 可調(diào)電阻怎么測量好壞

    可調(diào)電阻,也稱為電位器,是一種可以調(diào)節(jié)電阻值的電子元件。它通常有三個引腳:兩固定端和一可動端(或稱為中間抽頭)??烧{(diào)電阻的三個腳的連接方式
    的頭像 發(fā)表于 10-18 14:45 ?1920次閱讀

    三個電流怎么判斷NPN還是PNP

    在判斷晶體管是NPN型還是PNP型時,主要依據(jù)是其內(nèi)部半導(dǎo)體材料的排列方式以及電流在晶體管中的流動方向。闡述如何根據(jù)三個電流(通常指的是發(fā)射極電流IE、基極電流IB和集電極電流IC)來判斷NPN和PNP晶體管。
    的頭像 發(fā)表于 09-14 15:44 ?1394次閱讀

    基本理想電路元件的三個特征是什么

    基本理想電路元件是構(gòu)成電路的基本單元,它們具有三個基本特征:電壓-電流關(guān)系、能量轉(zhuǎn)換和電路參數(shù)。以下是對這三個特征的分析: 電壓-電流關(guān)系 理想電路元件的電壓-電流關(guān)系是其最基本的特征之一。這種關(guān)系
    的頭像 發(fā)表于 08-25 09:38 ?1184次閱讀

    對稱相電壓的特點是哪三個方面

    對稱相電壓是電力系統(tǒng)中常見的一種電壓形式,它具有三個相位,每個相位之間的相位差為120度。對稱相電壓在工業(yè)生產(chǎn)和日常生活中有著廣泛的應(yīng)用,如電動機(jī)、變壓器、發(fā)電機(jī)等。本文將從三個
    的頭像 發(fā)表于 08-12 18:18 ?1449次閱讀

    簡述極管的三個工作區(qū)域

    極管的三個區(qū)域,通常指的是其在不同工作條件下的狀態(tài)區(qū)域,即截止區(qū)、放大區(qū)和飽和區(qū)。這三個區(qū)域定義了極管在不同電壓和電流條件下的行為特性,對于理解和設(shè)計電子電路至關(guān)重要。
    的頭像 發(fā)表于 07-29 10:50 ?3682次閱讀

    可調(diào)變阻器三個引腳怎么區(qū)分

    可調(diào)變阻器,也稱為電位器或可變電阻器,是一種可以調(diào)節(jié)電阻值的電子元件。它廣泛應(yīng)用于各種電子設(shè)備中,如音頻設(shè)備、電源管理、電機(jī)控制等??烧{(diào)變阻器有三個引腳,分別是固定端、滑動端和可調(diào)端。這三個引腳
    的頭像 發(fā)表于 07-24 11:12 ?1333次閱讀

    espidf組件是否有json組包或者messagePack的庫文件?

    espidf組件是否有json組包或者messagePack的庫文件
    發(fā)表于 06-21 07:10

    微波測量的三個基本參量是什么

    微波測量是電子工程領(lǐng)域中的一重要分支,它涉及到對微波信號的頻率、幅度、相位等參數(shù)的測量。在微波測量中,有三個基本參量:頻率、幅度和相位。這三個參量是微波信號的基本特征,對于微波系統(tǒng)的設(shè)計、調(diào)試
    的頭像 發(fā)表于 05-28 14:46 ?1405次閱讀

    如何判斷極管的三個極性

    極管是電子電路中的基本元件之一,其性能的好壞直接影響到整個電路的性能。而判斷極管的三個極性(基極b、發(fā)射極e、集電極c)是電路分析和設(shè)計中不可或缺的一步。下面將詳細(xì)介紹判斷極管
    的頭像 發(fā)表于 05-21 15:26 ?6727次閱讀

    籬笆三個樁——記晶體極管的發(fā)明

    籬笆三個樁——記晶體極管的發(fā)明
    的頭像 發(fā)表于 05-12 08:14 ?766次閱讀
    一<b class='flag-5'>個</b>籬笆<b class='flag-5'>三個</b>樁——記晶體<b class='flag-5'>三</b>極管的發(fā)明

    人機(jī)交互的三個階段 人機(jī)交互的常用方式

    機(jī)交互經(jīng)歷的三個階段:命令行界面交互階段、圖形用戶界面交互階段、自然和諧的人機(jī)交互階段。
    的頭像 發(fā)表于 03-13 17:25 ?3146次閱讀

    基于Python的地圖繪制教程

    本文將介紹通過Python繪制地形圖的方法,所需第Python相關(guān)模塊包括 rasterio、geopandas、cartopy 等,可通過 pip 等方式
    的頭像 發(fā)表于 02-26 09:53 ?1235次閱讀
    基于<b class='flag-5'>Python</b>的地圖繪制教程

    飛機(jī)的三個舵面以及如何控制

    飛機(jī)通常具有三個主要的舵面,它們是方向舵(rudder)、副翼(aileron)和升降舵(elevator)。
    發(fā)表于 01-15 14:54 ?5994次閱讀
    飛機(jī)的<b class='flag-5'>三個</b>舵面以及如何控制