C++中TinyXML读取xml文件用法详解

目录
  • 前言
  • XML文件理解
  • 常用的XML类方法使用
  • 总结

前言

TinyXML下载地址:https://sourceforge.net/projects/tinyxml/

官方文档:TinyXML

TinyXML是个解析库,它由两个头文件(.h文件)和四个CPP文件(.cpp文件)构成,用的时候,只要将(tinyxml.h、tinystr.h、tinystr.cpp、tinyxml.cpp、tinyxmlerror.cpp、tinyxmlparser.cpp)导入工程就可以用它的东西了。如果需要,可以将它做成自己的DLL来调用。

XML文件理解

举一个官方文档《TinyXML Tutorial》中的例子

<?xml version="1.0" ?>
<MyApp>
<!-- Settings for MyApp -->
<Messages>
    <Welcome>Welcome to MyApp</Welcome>
    <Farewell>Thank you for using MyApp</Farewell>
</Messages>
<Windows>
<Window name="MainFrame" x="5" y="15" w="400" h="250" />
</Windows>
<Connection ip="192.168.0.1" timeout="123.456000" />
</MyApp>

XML是树形结构,有层数之分,其结点分为不同的类别,而TinyXML中针对不同类别定义了不同的类,下面简单介绍一下:(粗体是常用的)

  • <?xml version="1.0" ?>,TiXmlDeclaration,声明类
  • <MyApp>,TiXmlElement,元素类,该结点是根节点,后续的每个<></>都是一个结点
  • <!-- Settings for MyApp -->,TiXmlComment,注释类
  • Welcome to MyApp,TiXmlText,文本类,获取元素中的文本
  • TiXmlAttribute,属性类,name,x,y,w,h都是Window元素的属性

常用的XML类方法使用

接下来我们以一个目标检测的标签文件为例,来读取其中的boundingbox坐标信息。
XML文件:

<annotation>
    <folder>JPEGImages</folder>
    <filename>409.bmp</filename>
    <path>E:\JPEGImages\409.bmp</path>
    <source>
        <database>Unknown</database>
    </source>
    <size>
        <width>847</width>
        <height>419</height>
        <depth>3</depth>
    </size>
    <segmented>0</segmented>
    <object>
        <name>bad_part</name>
        <pose>Unspecified</pose>
        <truncated>0</truncated>
        <difficult>0</difficult>
        <bndbox>
            <xmin>512</xmin>
            <ymin>153</ymin>
            <xmax>693</xmax>
            <ymax>325</ymax>
        </bndbox>
    </object>
    <object>
        <name>bad_part</name>
        <pose>Unspecified</pose>
        <truncated>0</truncated>
        <difficult>0</difficult>
        <bndbox>
            <xmin>251</xmin>
            <ymin>251</ymin>
            <xmax>321</xmax>
            <ymax>313</ymax>
        </bndbox>
    </object>
</annotation>

文件中有两个boundingbox

获取bndbox元素下的最大最小坐标:

#include <iostream>
//打开xml文件需要加载的头文件
#include "tinystr.h"
#include "tinyxml.h"
#include <string>
#include<typeinfo>
using namespace std;

int main()
{
    //创建xml文件对象,并读取xml
    TiXmlDocument doc;
    doc.LoadFile("409.xml");

    //获取xml中根元素,并输出根节点的值,为<annotation>
    TiXmlElement *root = doc.FirstChildElement();
    cout << root->Value() << endl;

    //获取根节点孩子,输出节点值,输出节点的内容,Text是char*
    TiXmlElement *child = root->FirstChildElement();
    cout << child->Value() << endl;
    cout << child->GetText() << endl;
    cout << strlen(child->GetText())<< endl;
    //cout <<typeid(child->GetText()).name()<< endl;

    /*目标:找到xmin,xmax,ymin,ymax*/
    int xmin1,ymin1,xmax1,ymax1;
    //从根节点的第一个孩子节点开始遍历
    while(child!=NULL)
    {
        if(child->ValueTStr() == "object")
        {
            TiXmlElement *box = child->FirstChildElement();
            while(box->ValueTStr()!="bndbox")
            {
                box = box->NextSiblingElement();
            }

            TiXmlElement *xmin = box->FirstChildElement();
             xmin1 = atoi(xmin->GetText());
            //NextSiblingElement()获得同一层下一个节点
            TiXmlElement *ymin = xmin->NextSiblingElement();
             ymin1 = atoi(ymin->GetText());

            TiXmlElement *xmax = ymin->NextSiblingElement();
             xmax1 = atoi(xmax->GetText());

            TiXmlElement *ymax = xmax->NextSiblingElement();
             ymax1 = atoi(ymax->GetText());

             cout<<xmin1<<endl;
             cout<<ymin1<<endl;
             cout<<xmax1<<endl;
             cout<<ymax1<<endl;

        }
        child = child->NextSiblingElement();
    }

    /*
    cout<<xmin1<<endl;
    cout<<ymin1<<endl;
    cout<<xmax1<<endl;
    cout<<ymax1<<endl;
    */
    
    /*一些其他方法的测试*/
    /*
    //获取兄弟节点中的size节点
    TiXmlElement *brother = child->NextSiblingElement("size");
    cout << brother->Value() << endl;
    //cout << typeid(brother->GetText()).name()<< endl;

    //获取size节点下的属性值,<>中的属性,本例没有属性
    //cout <<brother->Attribute("width")<<endl;
    //找size下面节点width
    TiXmlElement *brother_child = brother->FirstChildElement();
    cout << brother_child->Value() << endl;
    cout << brother_child->GetText() << endl;

    //读取到内容,并转为int型,因为项目需要int数据
    int width = atoi(brother_child->GetText());
    cout << width << endl;
    */

    return 0;
}

总结

  • 主要是链表相关知识。
  • 常用的解析xml的方法。
  • char*转int类型用atoi,转float用atof,typeid返回变量类型。

到此这篇关于C++中TinyXML读取xml文件用法详解的文章就介绍到这了,更多相关C++ TinyXML读取xml内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • c++中用TINYXML解析XML文件

    TinyXML介绍 最近做一个负载均衡的小项目,需要解析xml配置文件,用到了TinyXML,感觉使用起来很容易,给出一个使用TinyXML进行XML解析的简单例子,很多复杂的应用都可以基于本例子的方法来完成. TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译.这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树. DOM模型即文档对象模型,是将整个文档分成多个元素(如书.章.节.段等),并利用树型

  • C++ TinyXML解析案例详解

    目录 TinyXML介绍 TinyXML类说明 下载和编译 简单的例子 读取XML 写入xml XML删除操作 XML修改操作 TinyXML介绍 最近做一个负载均衡的小项目,需要解析xml配置文件,用到了TinyXML,感觉使用起来很容易,给出一个使用TinyXML进行XML解析的简单例子,很多复杂的应用都可以基于本例子的方法来完成. TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译.这个解析库的模型通过解析XML文件,然后在内存中生成DOM

  • tinyxml 常用的C++ XML解析器非常优秀

    读取和设置xml配置文件是最常用的操作,试用了几个C++的XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API接口和Java的十分类似,面向对象性很好. TinyXML是一个开源的解析XML的解析库,能够用于C++,能够在Windows或Linux中编译.这个解析库的模型通过解析XML文件,然后在内存中生成DOM模型,从而让我们很方便的遍历这棵XML树. DOM模型即文档对象模型,是将整个文档分成多个元素(如书.章.节.段等),并利用树型结构表示这些元素之间的顺序关系以及嵌套包

  • C++使用TinyXML解析XML

    目录 1.介绍 2.TinyXML配置 3.TinyXML读取和保存文件 3.1 读取xml文件 3.2 读取xml参数 3.3 保存xml参数到文本 3.4 保存xml参数到临时变量 4.TinyXML增删改查 4.1 增 4.2 删 4.3 改 4.4 查 1.介绍 Tinyxml的官方网址:http://www.grinninglizard.com 官方介绍文档:http://www.grinninglizard.com/tinyxmldocs/tutorial0.html 在TinyXM

  • C++中TinyXML读取xml文件用法详解

    目录 前言 XML文件理解 常用的XML类方法使用 总结 前言 TinyXML下载地址:https://sourceforge.net/projects/tinyxml/ 官方文档:TinyXML TinyXML是个解析库,它由两个头文件(.h文件)和四个CPP文件(.cpp文件)构成,用的时候,只要将(tinyxml.h.tinystr.h.tinystr.cpp.tinyxml.cpp.tinyxmlerror.cpp.tinyxmlparser.cpp)导入工程就可以用它的东西了.如果需要

  • java 中maven pom.xml文件教程详解

    maven pom.xml文件教程详解,具体内容如下所示: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.x

  • Android 中读取Excel文件实例详解

    Android 中读取Excel文件实例详解 最近有个需求需要在app内置数据,新来的产品扔给了我两个Excel表格就不管了(两个表格格式还不统一...),于是通过度娘等方法找到了Android中读取Excel表格文件的一种方法,记录一下. 闲话一下Excel中工作簿和工作表的区别: 工作簿中包含有工作表.工作簿可以由一张或多张工作表组成,一个工作簿就是一个EXCEL表格文件. 好了,开始读取表格文件吧. 前提 首先,我们假设需要读取的表格文件名字为test.xls, 位于assets根目录下.

  • firefox中JS读取XML文件

    firefox中JS读取XML文件 在网上搜"firefox中JS读取XML文件"的方法,找了半天,好多都是问了没人答的.看到一堆程序员在抱怨firefox:"除了累死程序员没什么好处.",言归正传.firefox不支持ie中的ActiveXObject对象,要得到一个XML DOM有以下2种方法:1.document.implementation.createDocument("", "", null);2.window.X

  • Linux中 sed 和 awk的用法详解

    sed用法: sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换.删除.新增.选取等特定工作,下面先了解一下sed的用法 sed命令行格式为: sed [-nefri] 'command' 输入文本 常用选项: -n∶使用安静(silent)模式.在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上.但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来. -e∶直接在指令列模式上进行 sed 的

  • Python中index()和seek()的用法(详解)

    1.index() 一般用处是在序列中检索参数并返回第一次出现的索引,没找到就会报错,比如: >>> t=tuple('Allen') >>> t ('A', 'l', 'l', 'e', 'n') >>> t.index('a') Traceback (most recent call last): File "<pyshell#2>", line 1, in <module> t.index('a') V

  • java 读取本地文件实例详解

    java 读取本地文件实例详解 用javax.xml.w3c解析 实例代码: package cn.com.xinli.monitor.utils; import org.w3c.dom.Document; import org.w3c.dom.Element; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import java.io.File; /** *

  • c++中的两种getline用法详解

    getline是C++标准库函数:但不是C标准库函数,而是POSIX(IEEE Std 1003.1-2008版本及以上)所定义的标准库函数(在POSIX IEEE Std 1003.1-2008标准出来之前,则只是GNU扩展库里的函数).getline会生成一个包含一串从输入流读入的字符的字符串,直到以下情况发生会导致生成的此字符串结束:1)到文件结束,2)遇到函数的定界符,3)输入达到最大限度. getline()函数是一个比较常见的函数.根据名字直接"望文->生义",就知道

  • python处理xml文件操作详解

    目录 1.python 操作xml的方式介绍 2.ElementTree模块 3.解析xml格式字符串并获取根节点 4.读取节点内容,getroot() 5.通标标签名直接获取标签(find,findall) 6.全文搜索标签名(类似xpath路径查找标签) 7.修改节点 8.删除节点 9.构建文件 方式1 (Element) 方式2 (makeelement) 方式3 1.python 操作xml的方式介绍 查看全部包含“三种⽅法: ⼀是xml.dom. * 模块,它是W3CDOMAPI的实现

  • java 中HttpClient传输xml字符串实例详解

    java 中HttpClient传输xml字符串实例详解 介绍:我现在有一个对象page,需要将page对象转换为xml格式并以binary方式传输到服务端 其中涉及到的技术点有: 1.对象转xml流 2.输出流转输入流 3.httpClient发送二进制流数据 POM文件依赖配置 <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifact

随机推荐