电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:4日期: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 # 導入ElementTree模塊 # elemnt為傳進來的Elment類,參數indent用于縮進,newline用于換行def prettyXml(element, indent, newline, level = 0): # 判斷element是否有子元素 if element: # 如果element的text沒有內容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轉成list for subelement in temp:# 如果不是list的最后一個元素,說明下一個行是同級別元素的起始,縮進應一致if temp.index(subelement) < (len(temp) - 1): subelement.tail = newline + indent * (level + 1)else: # 如果是list的最后一個元素, 說明下一行是母元素的結束,縮進應該少一個 subelement.tail = newline + indent * level # 對子元素進行遞歸操作 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這個文件,該文件內容如上文 root = tree.getroot() #得到根元素,Element類 prettyXml(root, ’t’, ’n’) # 執行美化方法 #ElementTree.dump(root) #顯示出美化后的XML內容 tree.write(os.path.join(dir, fileName), encoding = ’utf-8’)

 補充:Python 標準庫 xml 詳解

對于簡單的 XML 解析處理, 可以使用標準庫 xml, 相對于第三方庫 lxml, xml 無需額外安裝, 但 xml 是用 Python 實現的, 性能不如 lxml

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

示例數據, 命名為 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>

導入要解析的 XML 文檔, 并獲取文檔的根節點

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

也可以直接解析字符串

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

對于每一個節點 Element:

通過列表接口可以訪問直接子節點

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

其他還有 tag 屬性表示標簽名, text 表示其包含的文本內容

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

打印輸出

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

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

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

<class ’str’> 曹雪芹

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

遞歸函數, 可以遍歷所有的后代節點

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

打印輸出

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

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

XPath 語法

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

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

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

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

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

# . 表示 bookstore 節點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)

打印結果

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

三國志作者: 陳壽

findtext 類似于 find, 直接獲取節點的文本內容

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

打印結果

True

吳承恩 明朝

羅貫中 明末清初

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

標簽: Python 編程
主站蜘蛛池模板: 武汉刮刮奖_刮刮卡印刷厂_为企业提供门票印刷_武汉合格证印刷_现金劵代金券印刷制作 - 武汉泽雅印刷有限公司 | 骨龄仪_骨龄检测仪_儿童骨龄测试仪_品牌生产厂家【品源医疗】 | 雷达液位计_超声波风速风向仪_雨量传感器_辐射传感器-山东风途物联网 | 非小号行情 - 专业的区块链、数字藏品行情APP、金色财经官网 | 空心明胶胶囊|植物胶囊|清真胶囊|浙江绿键胶囊有限公司欢迎您! | 作文导航网_作文之家_满分作文_优秀作文_作文大全_作文素材_最新作文分享发布平台 | 泰安办公家具-泰安派格办公用品有限公司 | 巩义市科瑞仪器有限公司| 台式核磁共振仪,玻璃软化点测定仪,旋转高温粘度计,测温锥和测温块-上海麟文仪器 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 细砂提取机,隔膜板框泥浆污泥压滤机,螺旋洗砂机设备,轮式洗砂机械,机制砂,圆锥颚式反击式破碎机,振动筛,滚筒筛,喂料机- 上海重睿环保设备有限公司 | 翅片管换热器「型号全」_厂家-淄博鑫科环保 | 电子海图系统-电梯检验系统-智慧供热系统开发-商品房预售资金监管系统 | 北京三友信电子科技有限公司-ETC高速自动栏杆机|ETC机柜|激光车辆轮廓测量仪|嵌入式车道控制器 | 干式磁选机_湿式磁选机_粉体除铁器-潍坊国铭矿山设备有限公司 | 齿轮减速机_齿轮减速电机-VEMT蜗轮蜗杆减速机马达生产厂家瓦玛特传动瑞环机电 | 真空吸污车_高压清洗车厂家-程力专用汽车股份有限公司官网 | 莱州网络公司|莱州网站建设|莱州网站优化|莱州阿里巴巴-莱州唯佳网络科技有限公司 | 超声波气象站_防爆气象站_空气质量监测站_负氧离子检测仪-风途物联网 | 金属检测机_金属分离器_检针验针机_食品药品金属检探测仪器-广东善安科技 | 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 超声波_清洗机_超声波清洗机专业生产厂家-深圳市好顺超声设备有限公司 | 连续油炸机,全自动油炸机,花生米油炸机-烟台茂源食品机械制造有限公司 | 壹作文_中小学生优秀满分作文大全| Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 海德莱电力(HYDELEY)-无功补偿元器件生产厂家-二十年专业从事电力电容器 | 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 锂电池生产厂家-电动自行车航模无人机锂电池定制-世豹新能源 | 分子精馏/精馏设备生产厂家-分子蒸馏工艺实验-新诺舜尧(天津)化工设备有限公司 | 气胀轴|气涨轴|安全夹头|安全卡盘|伺服纠偏系统厂家-天机传动 | 钢托盘,铁托盘,钢制托盘,镀锌托盘,饲料托盘,钢托盘制造商-南京飞天金属13260753852 | 香港新时代国际美容美发化妆美甲培训学校-26年培训经验,值得信赖! | 电加热导热油炉-空气加热器-导热油加热器-翅片电加热管-科安达机械 | 武汉高低温试验机-现货恒温恒湿试验箱-高低温湿热交变箱价格-湖北高天试验设备 | 超细|超微气流粉碎机|气流磨|气流分级机|粉体改性机|磨粉机|粉碎设备-山东埃尔派粉体科技 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | 机制砂选粉机_砂石选粉机厂家-盐城市助成粉磨科技有限公司 | 防水套管厂家-柔性防水套管-不锈钢|刚性防水套管-天翔管道 | 西安中国国际旅行社(西安国旅) | 优考试_免费在线考试系统_培训考试系统_题库系统_组卷答题系统_匡优考试 |