婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python 生成xml文件,以及美化的實例代碼

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

熱門標(biāo)簽:蓋州市地圖標(biāo)注 浙江電銷卡外呼系統(tǒng)好用嗎 地圖標(biāo)注的意義點 地圖制圖標(biāo)注位置改變是移位嗎 南京銷售外呼系統(tǒng)軟件 房產(chǎn)電銷外呼系統(tǒng) 上海機器人外呼系統(tǒng)哪家好 地圖標(biāo)注微信發(fā)送位置不顯示 315電話機器人廣告

看代碼吧~

# -*- coding:utf-8 -*- 
import os
import json
import numpy as np 
#from xml.etree import ElementTree as  etree
from xml.etree.ElementTree import Element
from xml.etree.ElementTree import SubElement
from xml.etree.ElementTree import ElementTree
 
imagePath = r'E:\Desktop\SteelCoilsDetection\test\images'
jsonPath = r'E:\Desktop\SteelCoilsDetection\test\json'
savePath = r'E:\Desktop\SteelCoilsDetection\test\xml'
 
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 os
from 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:\Desktop\SteelCoilsDetection\test\xml'
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')

 補充: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 ET
tree = 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].text
print(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)系, "http://"表示所有的子節(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").text
author_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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Python實現(xiàn)K-means聚類算法并可視化生成動圖步驟詳解
  • python3使用迭代生成器實現(xiàn)減少內(nèi)存占用
  • python實現(xiàn)由數(shù)組生成對稱矩陣
  • python自動化之如何利用allure生成測試報告
  • python基于opencv批量生成驗證碼的示例
  • 用python自動生成日歷
  • python2利用wxpython生成投影界面工具的圖文詳解
  • 用Python生成N層的楊輝三角的實現(xiàn)方法
  • Python生成九宮格圖片的示例代碼
  • python生成隨機數(shù)、隨機字符、隨機字符串的方法示例
  • python學(xué)習(xí)之可迭代對象、迭代器、生成器
  • python opencv 找出圖像中的最大輪廓并填充(生成mask)
  • Python .py生成.pyd文件并打包.exe 的注意事項說明
  • python實戰(zhàn)之用emoji表情生成文字

標(biāo)簽:克拉瑪依 臨汾 貴州 陽泉 金華 日照 赤峰 雙鴨山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python 生成xml文件,以及美化的實例代碼》,本文關(guān)鍵詞  python,生成,xml,文件,以及,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python 生成xml文件,以及美化的實例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于python 生成xml文件,以及美化的實例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91在线精品一区二区| 国产在线乱码一区二区三区| 日韩精品成人一区二区在线| 99精品欧美一区二区三区小说| 日韩午夜激情电影| 日韩电影免费在线观看网站| 欧美三级视频在线| 亚洲一区二区三区三| 一本到不卡免费一区二区| 国产精品美女久久久久高潮| 国产成人啪免费观看软件| 国产亚洲短视频| 亚洲影视在线播放| 欧美剧情片在线观看| 日本在线不卡一区| 欧美一卡二卡在线观看| 国产一区三区三区| 中文字幕二三区不卡| 日本丶国产丶欧美色综合| 亚洲欧洲成人自拍| 欧美婷婷六月丁香综合色| 三级精品在线观看| 国产日韩在线不卡| 99精品黄色片免费大全| 亚洲宅男天堂在线观看无病毒| 欧美亚洲一区二区三区四区| 免费观看在线色综合| 国产欧美日韩亚州综合| 91美女福利视频| 美日韩一区二区| 精品999在线播放| 91一区二区在线观看| 视频一区二区三区中文字幕| 2019国产精品| 在线免费观看日本欧美| 开心九九激情九九欧美日韩精美视频电影 | 欧美精品日韩精品| 欧美一区二区三区男人的天堂| 亚洲成a人在线观看| 欧美国产成人精品| 成人黄色在线视频| 精品一区二区国语对白| 亚洲欧美日韩成人高清在线一区| 精品卡一卡二卡三卡四在线| 成人黄色免费短视频| 三级在线观看一区二区| 一区二区三区日韩| 伊人夜夜躁av伊人久久| 国产精品传媒入口麻豆| 欧美高清在线一区二区| 久久久美女毛片| 精品久久久久一区| 国产精品私人影院| 日韩欧美一区二区视频| 99久久99久久精品国产片果冻| 国产精品一级二级三级| 视频一区视频二区在线观看| 午夜久久久久久| 久久精品99国产精品日本| 五月天亚洲婷婷| 久久精品国产久精国产| 蜜桃视频一区二区三区| 日本aⅴ精品一区二区三区| 久久人人爽爽爽人久久久| 精品久久人人做人人爽| 亚洲天堂av一区| 欧美日韩久久久久久| 欧美日韩成人高清| 日韩色在线观看| 日韩精品影音先锋| 亚洲黄色尤物视频| 日本系列欧美系列| 国产精品888| 色综合亚洲欧洲| 欧美欧美欧美欧美| 国产清纯美女被跳蛋高潮一区二区久久w| 久久综合色天天久久综合图片| 精品免费日韩av| 日韩和的一区二区| 国产久卡久卡久卡久卡视频精品| 欧美亚洲国产一卡| 国产精品亲子乱子伦xxxx裸| 亚洲人快播电影网| 国产一区啦啦啦在线观看| 欧美日韩激情一区| 亚洲精品一二三| 色欧美乱欧美15图片| 国产精品入口麻豆原神| 国产一区二区三区黄视频| 日韩午夜在线观看| 日日嗨av一区二区三区四区| 91国偷自产一区二区三区成为亚洲经典| 国产日韩欧美综合在线| 久久精品国产77777蜜臀| 综合久久久久久久| 日韩欧美在线网站| 狠狠色丁香婷综合久久| 高清国产一区二区| 精品福利在线导航| 国产不卡在线播放| 国产精品久久久久久久浪潮网站| 美国毛片一区二区三区| 精品入口麻豆88视频| 国产剧情av麻豆香蕉精品| 国产色产综合色产在线视频| 国产成人精品亚洲午夜麻豆| 一区二区三区在线影院| 3751色影院一区二区三区| 国产成人日日夜夜| 午夜电影久久久| 日本一区二区久久| 亚洲一区二区精品视频| 精品美女一区二区| 中文字幕国产精品一区二区| av一区二区三区| 久久国产精品99久久久久久老狼| 久久精品免视看| 2021久久国产精品不只是精品| 成人激情免费网站| 国内精品伊人久久久久av一坑| 亚洲精品伦理在线| 国产欧美日韩另类一区| 日韩女优毛片在线| 在线亚洲人成电影网站色www| 国产露脸91国语对白| 一区二区三区国产豹纹内裤在线| 久久久精品国产免费观看同学| 日韩欧美中文一区| 欧美一级国产精品| 欧美mv日韩mv国产| 亚洲一区二区3| 亚洲自拍偷拍图区| 日本不卡一二三| 亚洲综合999| 美腿丝袜亚洲综合| 国产福利91精品一区二区三区| 国产一区二区久久| 国产高清精品久久久久| 国产成人精品1024| 欧美性受极品xxxx喷水| 欧美日韩国产高清一区| 久久色在线观看| 亚洲精品视频一区| 久久国产精品99久久久久久老狼| 国产精品伊人色| 欧美日韩免费不卡视频一区二区三区| 日韩欧美你懂的| 一区二区三区色| 蓝色福利精品导航| 一区二区三区精品久久久| 欧美日韩在线播放三区四区| 国产麻豆欧美日韩一区| 中文字幕免费观看一区| 91久久国产综合久久| 国产一区二区免费视频| 亚洲欧美日韩中文播放| 亚洲精品网站在线观看| 一区二区三区中文免费| 久久久噜噜噜久久人人看 | 成人动漫中文字幕| 日本欧美大码aⅴ在线播放| 337p粉嫩大胆色噜噜噜噜亚洲 | 亚洲图片欧美一区| 国产另类ts人妖一区二区| 亚洲精品乱码久久久久久日本蜜臀| 日韩欧美一级特黄在线播放| 在线观看欧美精品| 日韩精品乱码免费| 精品伊人久久久久7777人| 大白屁股一区二区视频| 国产成人在线免费| 久久嫩草精品久久久精品一| 日韩三级免费观看| 国产精品久久久99| 成人精品gif动图一区| 成人美女在线观看| 日韩精品一区二区三区在线| 青青草成人在线观看| 中文字幕在线一区二区三区| 最新日韩av在线| 91在线看国产| 蜜臀99久久精品久久久久久软件| 国产成a人无v码亚洲福利| 在线日韩一区二区| 天堂精品中文字幕在线| 九九精品一区二区| 91亚洲国产成人精品一区二三| 国产日韩欧美精品一区| 欧美影视一区二区三区| 中文字幕一区免费在线观看| 欧美日韩在线播放| 紧缚奴在线一区二区三区| 99re热这里只有精品免费视频| 欧美国产丝袜视频| 国产片一区二区三区| 欧美精品一级二级| 精品一区二区三区的国产在线播放 | 日韩精品久久理论片| 一区av在线播放| 精品国产欧美一区二区|