- 首先此json格式的标注来自于阿里天池竞赛 街景字符编码识别
- 其次json转xml的脚本不能万能的,因为每个json文件的内部会略有不同
- 此例的json内部格式如下
转化后的xml格式如下(就拿第一个标注举例)
4.脚本文件如下
from xml.dom.minidom import parseString
import xml.dom.minidom
import os
import cv2
import json
_IMAGE_PATH = 'E:/coco/COCO/train'
_INDENT = '' * 4
_NEW_LINE = '\n'
_FOLDER_NODE = 'yaoganDataSet'
_ROOT_NODE = 'annotation'
_DATABASE_NAME = ''
_ANNOTATION = 'COCO2014'
_AUTHOR = 'li'
_SEGMENTED = '0'
_DIFFICULT = '0'
_TRUNCATED = '0'
_POSE = 'Unspecified'
_ANNOTATION_SAVE_PATH = 'Q:/tianchi_competition/Street_Recognization/Annotations'
# 封装创建节点的过程
def createElementNode(doc, tag, attr): # 创建一个元素节点
element_node = doc.createElement(tag)
# 创建一个文本节点
text_node = doc.createTextNode(attr)
# 将文本节点作为元素节点的子节点
element_node.appendChild(text_node)
return element_node
def createChildNode(doc, tag, attr, parent_node):
child_node = createElementNode(doc, tag, attr)
parent_node.appendChild(child_node)
if __name__ == "__main__":
json_path = "Q:/tianchi_competition/Street_Recognization/1/"
img_path = "Q:/tianchi_competition/Street_Recognization/JPEGImages/"
json_path1=os.path.j