txt2xml.py

# -*- coding: utf-8 -*-
"""
根据txt生成xml文件,txt格式为class xmin xmax ymin ymax
@author: bai
"""
import argparse
import os,cv2

try:
    import xml.etree.cElementTree as ET
except ImportError:
    import xml.etree.ElementTree as ET

class gen_xml():
    def __init__(self,root='annotation'):
        '''
        最多3层
        '''
        self.root_a = ET.Element(root)
        
        self.sub_root_a = None
        self.sub_sub_root_a = None
        
    def set_sub_node(self,last,sub_node,val):#last = root','sub_root' or 'sub_sub_root'
        if last == 'root':
            b = ET.SubElement(self.root_a, sub_node)
            b.text = val
        elif last == 'sub_root':
            b = ET.SubElement(self.sub_root_a, sub_node)
            b.text = val
        elif last == 'sub_sub_root':
            b = ET.SubElement(self.sub_sub_root_a, sub_node)
            b.text = val
            
    def set_sub_root(self,last,sub_root):#last = root','sub_root'
        if last == 'root':
            self.sub_root_a = ET.SubElement(self.root_a, sub_root)
        elif last == 'sub_root':
            self.sub_sub_root_a = ET.SubElement(self.sub_root_a, sub_root)
    def out(self,filename):
        fp = open(filename,'wb')
        tree = ET.ElementTree(self.root_a)
        tree.write(fp)
        fp.close()
        
def parse_args():
    """Parse input arguments."""
    parser = argparse.ArgumentParser(description='txt2xml demo')
    parser.add_argument('--JPEGImages','-J', dest='image_path',type=str, help='JPEGImages path to read',
                        default='None')
    parser.add_argument('--txt','-T', dest='txt_path', help='txt path to read',
                        default='None')
    parser.add_argument('--Annotations','-A', dest='xml_path', help='xml path to save',
                        default='None')
    args = parser.parse_args()

    return args

def check_bbox(width,height,xmin,ymin,xmax,ymax):
    if xmin < 0:
        xmin = 0
    if xmin > width:
        xmin = width
    if xmax < 0:
        xmax = 0
    if xmax > width:
        xmax = width

    
    if ymin < 0:
        ymin = 0
    if ymin > height:
        ymin = height
    if ymax < 0:
        ymax = 0
    if ymax > height:
        ymax = height
    return xmin,ymin,xmax,ymax
def main(args):
    list_txt=os.listdir(args.txt_path)
#    list_need=['filename','size','name','part']
#    list_sub_need=['width','height','depth','xmin','ymin','xmax','ymax']
    if len(list_txt)==0:
        return
    
    for txt_name in list_txt:
        print(txt_name)
        txt=open(os.path.join(args.txt_path,txt_name),'r')
        image_name=os.path.join(args.image_path,txt_name.replace('.txt','.jpg'))
        img=cv2.imread(image_name)
        height=img.shape[0]
        width=img.shape[1]
        depth=img.shape[2]
        
        my_xml = gen_xml('annotation')
        my_xml.set_sub_node('root','filename','%s'%image_name)
        my_xml.set_sub_root('root','size')
        my_xml.set_sub_node('sub_root','%s'%'height','%s'%height)
        my_xml.set_sub_node('sub_root','%s'%'width','%s'%width)
        my_xml.set_sub_node('sub_root','%s'%'depth','%s'%depth)
        
        lines=txt.readlines()
        for line in lines:
            line=line.replace('\n','')
            class_name_coor=line.split(' ')
            xmin=int(float(class_name_coor[1]))
            ymin=int(float(class_name_coor[2]))
            xmax=int(float(class_name_coor[3]))
            ymax=int(float(class_name_coor[4]))
            
            xmin,ymin,xmax,ymax = check_bbox(width,height,xmin,ymin,xmax,ymax)
            if xmax - xmin <= 30 and ymax - ymin <= 30:
                continue
                
             
            if len(class_name_coor)>=5:
                my_xml.set_sub_root('root','object')
                my_xml.set_sub_node('sub_root','name',class_name_coor[0])
                my_xml.set_sub_root('sub_root','bndbox')
                my_xml.set_sub_node('sub_sub_root','%s'%'xmin','%d'%xmin)
                my_xml.set_sub_node('sub_sub_root','%s'%'ymin','%d'%ymin)
                my_xml.set_sub_node('sub_sub_root','%s'%'xmax','%d'%xmax)
                my_xml.set_sub_node('sub_sub_root','%s'%'ymax','%d'%ymax)
                
        if os.path.exists(image_name):
            my_xml.out(os.path.join(args.xml_path,txt_name.replace('.txt','.xml')))

if __name__ == '__main__':
    args = parse_args()
    if args.image_path == 'None' or args.xml_path == 'None':
        exit(0)
    main(args)
    print('end')
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容