午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python實(shí)現(xiàn)xml轉(zhuǎn)json文件的示例代碼

瀏覽:17日期:2022-06-30 18:10:12

使用了Python的 xml.etree.ElementTree 庫(kù)

xml.etree.ElementTree 庫(kù)簡(jiǎn)介

xml.etree.ElementTree模塊實(shí)現(xiàn)了一個(gè)簡(jiǎn)單而高效的API用于解析和創(chuàng)建XML數(shù)據(jù)。xml.etree.ElementTree模塊對(duì)于惡意構(gòu)造的數(shù)據(jù)是不安全的。如果您需要解析不受信任或未經(jīng)驗(yàn)證的數(shù)據(jù),請(qǐng)參閱XML漏洞。參考文獻(xiàn):https://docs.python.org/3.6/library/xml.etree.elementtree.html

from xml.etree import ElementTreeimport jsonLISTTYPE = 1DICTTYPE = 0def getDictResults(res_dicts, iters): result_dicts = {} for iter in iters.getchildren(): iterxml(iter, result_dicts) if result_dicts: res_dicts[iters.tag].update(result_dicts)def getListResults(res_dicts, iters): result_lists = [] for iter in iters.getchildren(): result_dicts = {} iterxml(iter, result_dicts) result_lists.append(result_dicts.copy()) del(result_dicts) if result_lists: if len(res_dicts[iters.tag].items()) == 0: res_dicts[iters.tag] = result_lists.copy() else: for resobj in result_lists:resobjkey = list(resobj.keys())[0]if res_dicts[iters.tag].get(resobjkey) == None: res_dicts[iters.tag].update(resobj)else: if type(res_dicts[iters.tag][resobjkey]) == list: res_dicts[iters.tag][resobjkey].append(resobj[resobjkey].copy()) else: old_value = res_dicts[iters.tag][resobjkey] res_dicts[iters.tag][resobjkey] = [] res_dicts[iters.tag][resobjkey].append(old_value) res_dicts[iters.tag][resobjkey].append(resobj[resobjkey].copy()) del(result_lists)def checkxmlchildrentype(iters): taglist = [] for iter in iters.getchildren(): taglist.append(iter.tag) if len(set(taglist)) == len(taglist): return DICTTYPE else: return LISTTYPEdef getResults(res_dicts, iters): if checkxmlchildrentype(iters): return getListResults(res_dicts, iters) else: return getDictResults(res_dicts, iters)#@res_dicts {}def iterxml(iter, res_dicts): res_dicts[iter.tag] = {} if iter.attrib: for k,v in dict(iter.attrib).items(): res_dicts[iter.tag].update({k : v}) if iter.text is not None and iter.text.strip() != '': res_dicts[iter.tag].update({'__XmlTagText__' : iter.text.strip()}) if iter.getchildren(): getResults(res_dicts, iter)def parserxmltojson(file_path): try: tree = ElementTree.parse(file_path) except Exception as e: #multi-byte encodings are not supported 把字符集改成utf-8就可以 #encoding specified in XML declaration is incorrect xml encoding標(biāo)識(shí)和文件的字符集不同 #syntax error 語(yǔ)法錯(cuò)誤,亂碼等 #not well-formed (invalid token) 編輯器點(diǎn)擊后字符集被修改成ASCII等,或者文件本身字符集和xml encoding不相同 print('Parser {} Error, Errmsg: {}'.format(file_path, e)) return '' if tree is None: print('{} is None.'.format(file_path)) return '' root = tree.getroot() report = {} iterxml(root, report) #return getDictResults(root) return reportif __name__ == '__main__': jsonret = parserxmltojson('test.xml') with open('test.json', 'w', encoding='utf-8') as fd: fd.write(json.dumps(jsonret, ensure_ascii=False, indent=4)) print(json.dumps(jsonret, ensure_ascii=False, indent=4))

以上就是python實(shí)現(xiàn)xml轉(zhuǎn)json文件的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于python實(shí)現(xiàn)xml轉(zhuǎn)json文件的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧美午夜精品一区二区 | 一区二区视频在线免费观看 | 欧美中文日韩 | 黄色一大片 | 久草精品视频在线观看 | 伊人久久中文 | 蜜臀久久99精品久久一区二区 | 天天狠天天操 | 午夜影院免费观看 | 色综合视频在线 | 精品日韩在线观看 | 亚洲天堂日本 | 国产999在线| 日韩成人精品一区二区 | 欧美天天视频 | 四虎视频国产精品免费 | 欧美日韩看片 | 青草视频在线 | 日本爱爱网址 | 蜜桃av噜噜一区二区三区 | 91丨porny丨海角社区 | 国产一区二区视频在线观看 | 麻豆久久久久久久 | 亚洲午夜视频 | 久草这里只有精品 | 亚洲一区二区在线播放 | 殴美黄色大片 | 久久久久1 | 精品一区二区三区免费毛片 | 欧美午夜精品一区二区三区 | 国产又色又爽又黄又免费 | 激情综合五月天 | 国产免费av网站 | 日韩av资源 | 中文字幕一区二区av | av资源共享 | 亚洲一区二区三区在线免费观看 | 日韩一级网站 | 婷婷丁香综合 | 俺去啦最新网址 | 精品成人国产 |