欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python封裝json格式字符串并處理單雙引號問題

 更新時間:2022年02月18日 08:53:16   作者:RayChiu_Labloy  
大家好,本篇文章主要講的是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)文章

最新評論