成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python 處理 JSON 我選擇 ujson 和 orjson

開發 后端
在 Python 使用用 json.dumps(data) 時突然發現特別慢,data 本身不大,但是一個包含很多元素的列表,所以促使本人尋找一個替代的 JSON 處理庫。

 [[422355]]

在 Python 使用用  json.dumps(data) 時突然發現特別慢,data 本身不大,但是一個包含很多元素的列表,所以促使本人尋找一個替代的 JSON 處理庫。大概對比了一個 ujson(UtltraJSON), python-rapidjson(RapidJSON) 和 Python 自帶的 json 庫。還有一個 simplejson 是為兼容 Python 2.6 以前用的(json 是 Python 2.6 新加入的 API),性能有些差。

基本上姜還是老的辣,想要收獲更好的性能,還得仰賴傳統的 C/C++ 語言,ujson 是用純 C 寫的,RapidJSON 是 C++ 寫的,后者還是十美分的開源產品。json, ujson, rapidjson 三者 loads() 方法的性能差別不太明顯,但 dumps() 大對象時 Python 自帶的 json 庫就要考驗用戶的耐心了。

注:最開始本來認定了 ujson 為最佳選擇, 所以先從 usjon 和 rapidjson 切入的,后來寫作本文的過程中,從 usjon 的自我介紹中發現了 Rust 寫的 orjson 很顯眼,才加入了 orjson 的測試,看來 orjson 更值得擁有。

以上三個 json 組件的安裝方式分別為

pip install python-rapidjson

$ pip install simplejson

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

  1. # test.py  
  2. from time import time  
  3. import sys  
  4. import string  
  5. num = int(sys.argv[1])  
  6. lib = sys.argv[2]  
  7. items = []  
  8. for i in range(num):  
  9.     items.append({c:c for c in string.ascii_letters})  
  10. start = time()  
  11. if lib == 'ujson':  
  12.     import ujson  
  13.     ujson.dumps(items)  
  14. elif lib == 'rapidjson':  
  15.     import rapidjson  
  16.     rapidjson.dumps(items)  
  17. else:  
  18.     import json  
  19.     json.dumps(items)  
  20. print(time() - start) 

執行 python 1000|10000|100000|1000000 json|ujson|rapidjson, 試結果統計如下(數字為不同情況下的耗時):

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

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

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

  1. elif lib == 'orjson':  
  2.     import orjson  
  3.     orjson.dumps(items) 

再列出完整的對比數據

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

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

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

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

  1. >>> import ujson  
  2. >>> ujson.dumps({'a': 1, 'b': 2})  
  3. '{"a":1,"b":2}'  
  4. >>> ujson.dumps({'a': 1, 'b': 2}, indent=0 
  5. '{"a":1,"b":2}'  
  6. >>> ujson.dumps({'a': 1, 'b': 2}, indent=1 
  7. '{\n "a": 1,\n "b": 2\n}'  
  8. >>> ujson.dumps({'a': 1, 'b': 2}, indent=2 
  9. '{\n "a": 1,\n "b": 2\n}'  
  10. >>> ujson.dumps({'a': 1, 'b': 2}, indent=8 
  11. '{\n "a": 1,\n "b": 2\n}' 

indent 大于 1 時都當作 1。

換回到 ujson 2.0.3 版本時沒問題 

  1. >>> import ujson  
  2. >>> ujson.dumps({'a': 1, 'b': 2}, indent=2 
  3. '{\n  "a": 1,\n  "b": 2\n}'  
  4. >>> ujson.dumps({'a': 1, 'b': 2}, indent=8 
  5. '{\n        "a": 1,\n        "b": 2\n}' 

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

 

責任編輯:龐桂玉 來源: 馬哥Linux運維
相關推薦

2022-06-06 07:50:55

PythonJSON

2022-06-29 08:55:46

orjsonPythonJSON

2023-06-06 08:21:56

CSVJSONPython

2023-06-07 08:50:40

PythonCSV

2021-11-11 12:45:36

PythonCSVJSON

2025-01-03 08:50:23

2019-07-22 08:49:37

PythonJSON編程語言

2012-02-28 09:11:51

語言Lua

2017-09-06 17:05:54

大數據處理流程處理框架

2018-04-03 10:33:15

大數據

2012-11-14 20:55:07

容錯服務器選型CIO

2013-10-22 15:18:19

2020-01-03 09:57:33

Microsoft SSQL數據庫

2010-10-25 18:25:01

用友財會軟件

2021-02-01 07:20:51

KafkaPulsar搜索

2020-08-19 08:20:23

Python開發GitHub

2023-11-13 08:28:50

CSVJSON數據

2021-04-06 11:07:02

字節跳動組織架構

2020-12-17 09:44:02

前端開發后端

2018-12-21 11:26:49

MySQLMongoDB數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品免费看 | 国产www.| 亚洲一区 中文字幕 | 伊人超碰 | 久久99视频这里只有精品 | 欧美日韩国产一区二区三区 | 欧美日韩毛片 | 亚洲黄色网址视频 | 性一交一乱一伦视频免费观看 | 中文字幕在线第一页 | 一区二区不卡 | 日韩在线中文 | 天堂久久天堂综合色 | 福利网址 | 自拍视频在线观看 | 欧美中国少妇xxx性高请视频 | 男女又爽又黄视频 | 日韩精品一区二区三区 | 天天操网 | 天天干视频 | 精品一区二区在线看 | 久久久久久99 | 午夜免费视频 | 成人精品在线观看 | 亚洲成人福利视频 | 精品国产一区二区三区性色av | 粉嫩一区二区三区性色av | 在线 丝袜 欧美 日韩 制服 | 一区二区三区久久久 | 日本在线精品视频 | 1区2区视频 | 91视视频在线观看入口直接观看 | 91中文字幕 | 欧美一级免费 | 一区二区三区欧美大片 | .国产精品成人自产拍在线观看6 | 在线2区 | 可以在线看的黄色网址 | 精品三区 | 国产成人99久久亚洲综合精品 | 自拍偷拍第一页 |