日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

python 生成xml文件,以及美化的實例代碼

瀏覽:25日期:2022-06-21 13:47:47
看代碼吧~

# -*- coding:utf-8 -*- import osimport jsonimport numpy as np #from xml.etree import ElementTree as etreefrom xml.etree.ElementTree import Elementfrom xml.etree.ElementTree import SubElementfrom xml.etree.ElementTree import ElementTree imagePath = r’E:DesktopSteelCoilsDetectiontestimages’jsonPath = r’E:DesktopSteelCoilsDetectiontestjson’savePath = r’E:DesktopSteelCoilsDetectiontestxml’ jsonList = os.listdir(jsonPath)for jsonName in jsonList: print(jsonName) readPath = os.path.join(jsonPath, jsonName) # 打開json文件 with open(readPath, ’r’) as file_loader:jsonDic = json.load(file_loader) # print(jsonDic.keys()) # dict_keys([’version’, ’flags’, ’shapes’, ’imagePath’, ’imageData’, ’imageHeight’, ’imageWidth’])# 生成xml文件 annotation = Element(’annotation’) folder = SubElement(annotation, ’folder’) folder.text = 'images' filename = SubElement(annotation, ’filename’) filename.text = jsonName.split(’.’)[0] path = SubElement(annotation, ’path’) path.text = imagePath + jsonName.split(’.’)[0] source = SubElement(annotation, ’source’) database = SubElement(source, ’database’) database.text = 'Unknown' size = SubElement(annotation, ’size’) width = SubElement(size, ’width’) width.text = str(jsonDic[’imageWidth’]) height = SubElement(size, ’height’) height.text = str(jsonDic[’imageHeight’]) depth = SubElement(size, ’depth’) depth.text = '3' segmented = SubElement(annotation, ’segmented’) segmented.text = '0' for shape in jsonDic[’shapes’]: if shape['label'] == ’a’: continue object = SubElement(annotation, ’object’) name = SubElement(object, ’name’)name.text = shape['label'] pose = SubElement(object, ’pose’)pose.text = ’Unspecified’ truncated = SubElement(object, ’truncated’)truncated.text = str(0) difficult = SubElement(object, ’difficult’)difficult.text = str(0) points = shape[’points’]mritx = np.array(points)xxmin = min(mritx[:, 0])xxmax = max(mritx[:, 0])yymin = min(mritx[:, 1])yymax = max(mritx[:, 1]) bndbox = SubElement(object, ’bndbox’)xmin = SubElement(bndbox, ’xmin’)xmin.text = str(int(xxmin))ymin = SubElement(bndbox, ’ymin’)ymin.text = str(int(yymin))xmax = SubElement(bndbox, ’xmax’)xmax.text = str(int(xxmax))ymax = SubElement(bndbox, ’ymax’)ymax.text = str(int(yymax)) tree = ElementTree(annotation) tree.write(os.path.join(savePath, jsonName.split(’.’)[0]+’.xml’), encoding = ’utf-8’)美化:

# -*- coding:utf-8 -*- import osfrom xml.etree import ElementTree # 導(dǎo)入ElementTree模塊 # elemnt為傳進(jìn)來的Elment類,參數(shù)indent用于縮進(jìn),newline用于換行def prettyXml(element, indent, newline, level = 0): # 判斷element是否有子元素 if element: # 如果element的text沒有內(nèi)容if element.text == None or element.text.isspace(): element.text = newline + indent * (level + 1)else: element.text = newline + indent * (level + 1) + element.text.strip() + newline + indent * (level + 1) # 此處兩行如果把注釋去掉,Element的text也會另起一行 #else:#element.text = newline + indent * (level + 1) + element.text.strip() + newline + indent * level temp = list(element) # 將elemnt轉(zhuǎn)成list for subelement in temp:# 如果不是list的最后一個元素,說明下一個行是同級別元素的起始,縮進(jìn)應(yīng)一致if temp.index(subelement) < (len(temp) - 1): subelement.tail = newline + indent * (level + 1)else: # 如果是list的最后一個元素, 說明下一行是母元素的結(jié)束,縮進(jìn)應(yīng)該少一個 subelement.tail = newline + indent * level # 對子元素進(jìn)行遞歸操作 prettyXml(subelement, indent, newline, level = level + 1) dir = r’E:DesktopSteelCoilsDetectiontestxml’for fileName in os.listdir(dir): print(fileName) tree = ElementTree.parse(os.path.join(dir, fileName)) #解析test.xml這個文件,該文件內(nèi)容如上文 root = tree.getroot() #得到根元素,Element類 prettyXml(root, ’t’, ’n’) # 執(zhí)行美化方法 #ElementTree.dump(root) #顯示出美化后的XML內(nèi)容 tree.write(os.path.join(dir, fileName), encoding = ’utf-8’)

 補(bǔ)充:Python 標(biāo)準(zhǔn)庫 xml 詳解

對于簡單的 XML 解析處理, 可以使用標(biāo)準(zhǔn)庫 xml, 相對于第三方庫 lxml, xml 無需額外安裝, 但 xml 是用 Python 實現(xiàn)的, 性能不如 lxml

XML 的解析功能主要由 xml.etree.ElementTree 模塊完成, 其中包含兩個類, ElementTree 用于表示整個 XML 文檔, 而 Element 表示文檔中的一個節(jié)點

示例數(shù)據(jù), 命名為 book.xml

<?xml version='1.0'?><bookstore><book name='西游記'><author>吳承恩</author><dynasty>明朝</dynasty><similar name='封神演義' author='許仲琳'/></book><book name='紅樓夢'><author>曹雪芹</author><dynasty>清朝</dynasty></book><book name='三國演義'><author>羅貫中</author><dynasty>明末清初</dynasty><similar name='三國志' author='陳壽'/></book></bookstore>

導(dǎo)入要解析的 XML 文檔, 并獲取文檔的根節(jié)點

import xml.etree.ElementTree as ETtree = ET.parse('./book.xml')root = tree.getroot()

也可以直接解析字符串

with open('./book.xml') as fp: root = ET.fromstring(fp.read())

對于每一個節(jié)點 Element:

通過列表接口可以訪問直接子節(jié)點

通過字典接口可以訪問屬性節(jié)點, 也可通過 attrib 屬性(例如 root.attrib)得到真正的字典

其他還有 tag 屬性表示標(biāo)簽名, text 表示其包含的文本內(nèi)容

# 遍歷直接子節(jié)點for book in root: print(book.tag, book.attrib, book.get('name'))# 訪問根節(jié)點下的第2個子節(jié)點, 再向下訪問第1個子節(jié)點的文本, 也就是 '<author>曹雪芹</author>'author = root[1][0].textprint(type(author), author)

打印輸出

book {’name’: ’西游記’} 西游記

book {’name’: ’紅樓夢’} 紅樓夢

book {’name’: ’三國演義’} 三國演義

<class ’str’> 曹雪芹

獲取到的文本結(jié)果與 lxml 不同, 這里的結(jié)果直接是字符串類型

遞歸函數(shù), 可以遍歷所有的后代節(jié)點

# 遞歸選擇所有標(biāo)簽名為 'similar' 的節(jié)點for book in root.iter('similar'): print(book.attrib)

打印輸出

{’name’: ’封神演義’, ’author’: ’許仲琳’}

{’name’: ’三國志’, ’author’: ’陳壽’}

XPath 語法

XPath 類似于文件路徑, 路徑中最末尾的部分表示要提取的內(nèi)容, 分隔符有兩種, '/'表示直接子節(jié)點的關(guān)系, '//'表示所有的子節(jié)點

語法 含義 tag 匹配特定標(biāo)簽 * 匹配所有元素 . 當(dāng)前節(jié)點, 用于相對路徑 … 父節(jié)點 [@attrib] 匹配包含 attrib 屬性的節(jié)點 [@attrib=‘value’] 匹配 attrib 屬性等于 value 的節(jié)點 [tag] 匹配包含直接子節(jié)點 tag 的節(jié)點 [tag=‘text’] 匹配包含直接子節(jié)點 tag 且子節(jié)點文本內(nèi)容為 text 的節(jié)點 [n] 匹配第 n 個節(jié)點

[] 前面必須有標(biāo)簽名, book[@name][similar] 匹配帶有 name 屬性以及 similar 直接子節(jié)點的 book 節(jié)點, 然后將 book[@name][similar] 置于 XPath 路徑中, 例如 “/bookstore/book[@name][similar]”

可以通過 Element 對象的方法 findall(path) 和 find(path) 使用 XPath 語法, 次時路徑是從 Element 代表的節(jié)點開始, 也可以通過 ElementTree 對象調(diào)用 findall 與 find, 相當(dāng)于路徑從根節(jié)點開始

匹配到節(jié)點, findall 返回所有匹配節(jié)點的列表, find 返回首個匹配節(jié)點, 沒有匹配到節(jié)點時, findall 返回空列表, find 返回 None

# . 表示 bookstore 節(jié)點author_1 = tree.find('./book[@name=’紅樓夢’]/author').textauthor_2 = tree.findtext('./book[@name=’紅樓夢’]/author')print('紅樓夢作者:', author_1, author_2)author_3 = root.find('./book/similar[@name=’三國志’]').get('author')print('三國志作者:', author_3)

打印結(jié)果

紅樓夢作者: 曹雪芹 曹雪芹

三國志作者: 陳壽

findtext 類似于 find, 直接獲取節(jié)點的文本內(nèi)容

books_1 = root.findall('./book[similar]')# 對于直接子節(jié)點, 可以省略 ./books_2 = root.findall('book[similar]')print(books_1 == books_2)for book in books_1: print(book[0].text, book[1].text)

打印結(jié)果

True

吳承恩 明朝

羅貫中 明末清初

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。如有錯誤或未考慮完全的地方,望不吝賜教。

標(biāo)簽: Python 編程
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费成人在线观看| av一区在线| 五月精品视频| 好吊视频一区二区三区四区| 亚洲天堂成人| 99视频一区| 亚洲精选91| 国产欧美日韩视频在线| 国产精品亚洲综合久久| 免费亚洲婷婷| 欧美福利专区| 午夜亚洲福利| 日韩1区2区| 国产高清久久| 国产日韩欧美三级| 黄色在线观看www| 香蕉人人精品| 日韩av中文在线观看| 国产中文在线播放| 免费在线观看视频一区| 国产极品模特精品一二| 日韩在线中文| 亚洲午夜久久| 婷婷激情一区| 日韩精品五月天| 亚洲成人一区在线观看| 亚洲精品韩国| 99国产精品一区二区| 欧美一区二区三区久久精品| 毛片在线网站| 日本少妇精品亚洲第一区| 精品久久久亚洲| 亚洲精品三级| 久久中文字幕av| 国产精品v日韩精品v欧美精品网站| 91精品国产乱码久久久久久久| 日韩福利在线观看| 国产主播一区| 精品久久网站| 欧美日韩亚洲一区| 亚洲欧美不卡| 久久久久国产一区二区| 国产日韩亚洲欧美精品| 日韩专区视频网站| 99pao成人国产永久免费视频| 国产黄大片在线观看| 91大神在线观看线路一区| 亚洲一区观看| 久久高清免费| 香蕉成人av| 97在线精品| 91免费精品| 中文字幕在线官网| 精品72久久久久中文字幕| 免费视频一区二区三区在线观看| 国产精品成人自拍| 国产精品久久久久久久久久齐齐 | 亚洲一级影院| 999久久久亚洲| 国产精品7m凸凹视频分类| 亚洲午夜电影| 免费中文字幕日韩欧美| 鲁大师成人一区二区三区| 鲁大师影院一区二区三区| 丝袜美腿亚洲一区二区图片| 国产精品嫩草99av在线| 一级成人国产| 国产乱码精品一区二区三区四区| 国产精品一站二站| 精品黄色一级片| 精品国产一区二区三区2021| 一区二区精品伦理...| 大香伊人久久精品一区二区 | 日韩欧美精品综合| 999久久久91| 亚洲精品乱码日韩| 国产精品久久久久9999高清| 欧美一级鲁丝片| 蜜芽一区二区三区| 麻豆视频久久| 蜜桃tv一区二区三区| 亚洲人成网77777色在线播放 | 日韩大片在线播放| 亚洲天堂成人| 91精品福利观看| 电影亚洲精品噜噜在线观看| 免费观看在线综合色| 久久精品国产亚洲一区二区三区| 午夜国产一区二区| 欧美激情麻豆| 丝袜国产日韩另类美女| 精品九九久久| 美女黄网久久| 福利片在线一区二区| 亚洲日本欧美| 日韩精品一区二区三区免费观影| 日韩精品导航| 欧美网站在线| 久久精品三级| 日本中文字幕一区二区视频| 日韩精品欧美| 美日韩一区二区三区| 日韩欧美中文字幕在线视频| 久久不射中文字幕| 久久免费黄色| 国产精品成人一区二区网站软件| 中文精品视频| 久久精品国产www456c0m| 麻豆91在线播放| 亚洲精品伊人| 尤物精品在线| 99久久亚洲精品| 亚洲综合电影| 老司机免费视频一区二区| 人人爱人人干婷婷丁香亚洲| 一区二区三区网站| 视频一区二区中文字幕| 在线国产一区| 午夜久久99| 亚洲一区日韩在线| 日韩天堂av| 亚洲综合中文| 亚州av一区| 蜜芽一区二区三区| 亚洲男人在线| 日韩国产欧美在线播放| 国产调教精品| 久久久久黄色| 国产成人精选| 久久久久99| 综合欧美亚洲| 国产精品美女午夜爽爽| 精品国产美女a久久9999| 久久电影tv| 亚洲综合不卡| 91成人精品观看| 美女av在线免费看| 亚洲综合不卡| 国产精品一区二区三区www| 国产精品777777在线播放| 国产在视频一区二区三区吞精| 日韩av福利| 中文字幕一区二区三区在线视频| 青青草国产成人99久久| 红杏一区二区三区| 99国产一区| 国产一区二区三区不卡av| 91久久亚洲| 美女视频一区在线观看| 一区二区视频欧美| 久久99青青| 视频一区在线播放| 日韩欧美精品一区| 国产日韩亚洲欧美精品| 狠狠操综合网| 国产精品天堂蜜av在线播放| 久久在线免费| 久久精品伊人| 免费美女久久99| 日韩免费福利视频| 欧美日韩在线精品一区二区三区激情综合 | 色在线视频观看| 亚洲资源网站| 九一成人免费视频| 精品三级久久久| 亚洲一区二区小说| 久久影视一区| 成年男女免费视频网站不卡| 亚洲欧美在线专区| 欧美特黄一级大片| 狠狠躁少妇一区二区三区| 国产欧美日韩综合一区在线播放| 日韩午夜高潮| 欧美中文一区二区| 电影91久久久| 国产精品成人国产| 国产劲爆久久| 亚洲黄色免费av| 日韩综合一区| 精品香蕉视频| 都市激情国产精品| 91精品二区| 男女性色大片免费观看一区二区 | 三级小说欧洲区亚洲区| 99久久亚洲精品蜜臀| 亚洲三级网址| 日本美女一区| 亚洲精品伊人| 日韩一区二区中文| 日本亚州欧洲精品不卡| 久久一区国产| 国产精品久久久久久久久久久久久久久 | 国产精品视频一区二区三区四蜜臂 | 国产精品试看| 亚洲精品无播放器在线播放| 国产精品亚洲欧美日韩一区在线| 国产精品99视频| 久久国产成人| 久久久久久久久成人| 欧美日韩国产综合网|