python封裝json格式字符串并處理單雙引號問題
在使用python做web服務的時候會有數(shù)據(jù)交互的情況,大多數(shù)目前會采用json格式的數(shù)據(jù)來交互,接收者接收到標準的json格式數(shù)據(jù)后,會比較方便解析數(shù)據(jù)。
我這里有一個場景是將三個數(shù)組類型的數(shù)據(jù)封裝成json格式的字符串并發(fā)送給消費方,三個數(shù)組類型的數(shù)據(jù)是:
print(boxes) print(scores) print(txts) #以下是打印結(jié)果 #第一個: [array([[292., 294.], [331., 293.], [349., 848.], [309., 850.]], dtype=float32), array([[339., 299.], [378., 298.], [392., 660.], [353., 662.]], dtype=float32)] #第二個: [0.9401206, 0.8182683] #第三個: ['土地整治與土壤修復研究中心', '華南農(nóng)業(yè)大學丨東圖']
我這樣封裝成str格式:
txts_str = "" for i in range(len(txts)): if (len(txts_str) == 0): txts_str = str(txts[i]) else: #因為是字符串句子,選一個不常用的符號“|”做間隔 txts_str = txts_str + "|" + str(txts[i]) txt_scores = "" for i in range(len(scores)): if(len(txt_scores) == 0): txt_scores = str(scores[i]) else: txt_scores = txt_scores + "|" + str(scores[i]) txt_boxes = "" for i in range(len(boxes)): for j in range(len(boxes[i])): for k in range(len(boxes[i][j])): if (len(txt_boxes) == 0): txt_boxes = str(boxes[i][j][k]) else: txt_boxes = txt_boxes + "," + str(boxes[i][j][k]) #打印一下 print(txt_boxes) print(txts_str) print(txt_scores) #打印結(jié)果: #292.0,294.0,331.0,293.0,349.0,848.0,309.0,850.0,339.0,299.0,378.0,298.0,392.0,660.0,353.0,662.0 #土地整治與土壤修復研究中心|華南農(nóng)業(yè)大學丨東圖 #0.9401206|0.8182683
封裝成json:
#然后封裝成json: result_data = {"txt_boxes": txt_boxes, "txts": txts, "txt_scores": txt_scores}
發(fā)現(xiàn)是單引號的格式,并不是標準json:
#{'txt_boxes': '292.0,294.0,331.0,293.0,349.0,848.0,309.0,850.0,339.0,299.0,378.0,298.0,392.0,660.0,353.0,662.0', 'txts': ['土地整治與土壤修復研究中心', '華南農(nóng)業(yè)大學丨東圖'], 'txt_scor es': '0.9401206|0.8182683'}
這樣將單引號轉(zhuǎn)為雙引號
json.dumps(result_data)
發(fā)現(xiàn)json.dumps后中文格式不對了:
#{"txt_boxes": "292.0,294.0,331.0,293.0,349.0,848.0,309.0,850.0,339.0,299.0,378.0,298.0,392.0,660.0,353.0,662.0", "txts": "\u571f\u5730\u6574\u6cbb\u4e0e\u571f\u58e4\u4fee\u590d\u7814\u7a76\u4e2d\u5fc3|\u534e\u5357\u519c\u4e1a\u5927\u5b66\u4e28\u4e1c\u56fe", "txt_scores": "0.9401206|0.8182683"}
這是因為json.dumps 序列化時默認使用的ascii編碼,想輸出真正的中文需要指定ensure_ascii=False:
json.dumps(result_data,ensure_ascii=False)
結(jié)果是我們要的標準json格式了:
#{"txt_boxes": "292.0,294.0,331.0,293.0,349.0,848.0,309.0,850.0,339.0,299.0,378.0,298.0,392.0,660.0,353.0,662.0", "txts": ["土地整治與土壤修復研究中心|華南農(nóng)業(yè)大學丨東圖"], "txt_scores": "0.9401206|0.8182683"}
到此這篇關(guān)于python封裝json格式字符串并處理單雙引號問題的文章就介紹到這了,更多相關(guān)python封裝json內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
pandas實現(xiàn)將dataframe滿足某一條件的值選出
今天小編就為大家分享一篇pandas實現(xiàn)將dataframe滿足某一條件的值選出,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06python用sqlacodegen根據(jù)已有數(shù)據(jù)庫(表)結(jié)構(gòu)生成對應SQLAlchemy模型
本文介紹了如何使用sqlacodegen獲取數(shù)據(jù)庫所有表的模型類,然后使用ORM技術(shù)進行CRUD操作,有此需求的朋友可以了解下本文2021-06-06python通過opencv實現(xiàn)圖片裁剪原理解析
這篇文章主要介紹了python通過opencv實現(xiàn)圖片裁剪原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-01-01