c++ 解析xml文件

解析的xml文件

<?xml version="1.0" encoding="utf-8"?><Objects><person><label>15</label><xmin>207</xmin><ymin>106</ymin><xmax>489</xmax><ymax>381</ymax><score>0.99566</score></person><person><label>15</label><xmin>546</xmin><ymin>57</ymin><xmax>912</xmax><ymax>395</ymax><score>0.984854</score></person><person><label>15</label><xmin>898</xmin><ymin>103</ymin><xmax>1223</xmax><ymax>382</ymax><score>0.958104</score></person><person><label>15</label><xmin>2</xmin><ymin>61</ymin><xmax>381</xmax><ymax>389</ymax><score>0.906186</score></person></Objects>

c++文件

#include <string>
#include <string.h>
#include <stdio.h>
#include "stdlib.h"
#include <libxml/xpath.h>
#include <libxml/parser.h>
#include <libxml/xmlmemory.h>
#include <libxml/xmlstring.h>
#include <jqw.h>int main()
{objects obj;
double fps;xmlDocPtr pDoc = xmlReadFile("parameter.xml", "UTF-8", XML_PARSE_RECOVER); //获取XML文档的指针if(NULL == pDoc){fprintf(stderr, "xmlParseFile Error in %s %d\n",__FUNCTION__, __LINE__);}xmlNodePtr pRoot = xmlDocGetRootElement(pDoc);//获取根节点if(NULL == pRoot){fprintf(stderr, "xmlDocGetRootElement Error in %s %d\n", __FUNCTION__, __LINE__);xmlFreeDoc(pDoc);}printf("Node name is %s!\n", pRoot->name);int i=0;xmlNodePtr pFirst = pRoot->xmlChildrenNode;//获取子节点while(NULL != pFirst){//printf("---------------i= %d\n", i);if(!xmlStrcmp(pFirst->name, (const xmlChar *)("person"))){xmlNodePtr pSecond = pFirst->xmlChildrenNode;while(NULL != pSecond){xmlChar* value= NULL;if(!xmlStrcmp(pSecond->name, (const xmlChar *)("label"))){i=i+1;value = xmlNodeGetContent(pSecond);//printf("\n%s-->%s\n", pSecond->name, value);char * stream = (char *) value;obj.p[i].lable=atoi(stream);printf("obj.person[%d].lable=%d\n",i,obj.p[i].lable);stream=NULL;xmlFree(value);value = NULL;}if(!xmlStrcmp(pSecond->name, (const xmlChar *)("xmin"))){value = xmlNodeGetContent(pSecond);//printf("\n%s-->%s\n", pSecond->name, value);char * stream = (char *) value;obj.p[i].xmin=atoi(stream);printf("obj.person[%d].xmin=%d\n",i,obj.p[i].xmin);stream=NULL;xmlFree(value);value = NULL;}if(!xmlStrcmp(pSecond->name, (const xmlChar *)("ymin"))){value = xmlNodeGetContent(pSecond);//printf("\n%s-->%s\n", pSecond->name, value);char * stream = (char *) value;obj.p[i].ymin=atoi(stream);printf("obj.person[%d].ymin=%d\n",i,obj.p[i].ymin);stream=NULL;xmlFree(value);value = NULL;}if(!xmlStrcmp(pSecond->name, (const xmlChar *)("xmax"))){value = xmlNodeGetContent(pSecond);//printf("\n%s-->%s\n", pSecond->name, value);char * stream = (char *) value;obj.p[i].xmax=atoi(stream);printf("obj.person[%d].xmax=%d\n",i,obj.p[i].xmax);stream=NULL;xmlFree(value);value = NULL;}if(!xmlStrcmp(pSecond->name, (const xmlChar *)("ymax"))){value = xmlNodeGetContent(pSecond);//printf("\n%s-->%s\n", pSecond->name, value);char * stream = (char *) value;obj.p[i].ymax=atoi(stream);printf("obj.person[%d].ymax=%d\n",i,obj.p[i].ymax);stream=NULL;xmlFree(value);value = NULL;}if(!xmlStrcmp(pSecond->name, (const xmlChar *)("score"))){value = xmlNodeGetContent(pSecond);char * stream = (char *) value;//printf("\n%s-->%s\n", pSecond->name, value);obj.p[i].score=atof(stream);printf("obj.person[%d].score=%f\n",i,obj.p[i].score);stream=NULL;xmlFree(value);value = NULL;}pSecond = pSecond->next;}}pFirst = pFirst->next;}obj.personnum=i;printf("obj.personnum=%d\n",obj.personnum);xmlFreeDoc(pDoc);return 0;
}
jqw.h

#ifndef   __JQW_H__
#define   __JQW_H__struct person{int lable;int xmin;int ymin;int xmax;int ymax;float score;
};struct objects
{person p[3];int personnum;
};
#endif
编译脚本

#!/bin/bash
#
#gcc -I/usr/include/libxml2  parse_xml.cpp -o CreateXmlFile -L /usr/lib/i386-linux-gnu -lxml2
echo "finish compile"echo "start run pragram!!!"exit 0



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/510311.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sdut 最少拦截系统

最少拦截系统 Time Limit: 1000MS Memory Limit: 65536KBSubmit Statistic DiscussProblem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.…

ubuntu下动态链接库的编译和使用实例

以下实例的环境是amd64 ubuntu10.10 g 4.4.5测试成功&#xff0c;在其他配置的机器上可能有一点区别。 动态库的使用方式中有两种&#xff0c;第一种是类似于静态库的使用&#xff0c;另一种我称之为真正的动态加载动态库&#xff0c;主要是因为这种方式在程序运行的过程中加载…

sdut 数据结构实验之栈四:括号匹配

数据结构实验之栈四&#xff1a;括号匹配 Time Limit: 1000MS Memory Limit: 65536KBSubmit Statistic DiscussProblem Description 给你一串字符&#xff0c;不超过50个字符&#xff0c;可能包括括号、数字、字母、标点符号、空格&#xff0c;你的任务是检查这一串字符中的( )…

解读Batch Normalization

【活动】Python创意编程活动开始啦&#xff01;&#xff01;&#xff01; CSDN日报20170424 ——《技术方向的选择》 程序员4月书讯&#xff1a;Angular来了&#xff01;解读Batch Normalization 2016-02-23 16:03 5262人阅读 评论(1) 收藏 举报 本文章已收录于&#xf…

Caffe学习系列(1):安装配置ubuntu14.04+cuda7.5+caffe+cudnn

Caffe学习系列(1)&#xff1a;安装配置ubuntu14.04cuda7.5caffecudnn 一、版本 linux系统&#xff1a;Ubuntu 14.04 &#xff08;64位&#xff09; 显卡&#xff1a;Nvidia K20c cuda: cuda_7.5.18_linux.run cudnn: cudnn-7.0-linux-x64-v4.0-rc 二、下载 Ubuntu 14.04下载地址…

将数据集做成VOC2007格式用于Faster-RCNN训练

[置顶] 将数据集做成VOC2007格式用于Faster-RCNN训练 2016-02-23 15:35 29068人阅读 评论(336) 收藏 举报 本文章已收录于&#xff1a; 分类&#xff1a; Deep Learning&#xff08;7&#xff09; 作者同类文章X版权声明&#xff1a;本文为博主原创文章&#xff0c;未经博主…

快速排序的实现--代码

#include<stdio.h>int a[10000]; void QickSort(int a[],int l,int r) {int temp;int il,jr;if(l<r){tempa[l];//存val的值while(i!j){while(j>i&&a[j]>temp) --j;// 从右往左找出该数比val值小的数if(i<j){a[i]a[j];//放在val的左 边i;//i右移动}wh…

SSD框架训练自己的数据集

SSD框架训练自己的数据集 SSD demo中详细介绍了如何在VOC数据集上使用SSD进行物体检测的训练和验证。本文介绍如何使用SSD实现对自己数据集的训练和验证过程&#xff0c;内容包括&#xff1a; 1 数据集的标注2 数据集的转换3 使用SSD如何训练4 使用SSD如何测试1 数据集的标注 …

归并排序的实现-代码

#include<stdio.h> void merge_sort(int *a,int *b,int x,int y) { if(y-x>1) { int mx(y-x)/2;//中间点的坐标 int px,qm,ix; merge_sort(a,b,x,m); merge_sort(a,b,m,y); while(p<m||q<y) { if(q>y||(p<m&&a[p]<a[q])) b[i]…

SSD+caffe︱Single Shot MultiBox Detector 目标检测+fine-tuning(二)

承接上一篇SSD介绍&#xff1a;SSDcaffe︱Single Shot MultiBox Detector 目标检测&#xff08;一&#xff09; 如果自己要训练SSD模型呢&#xff0c;关键的就是LMDB格式生成&#xff0c;从官方教程weiliu89/caffe来看&#xff0c;寥寥几行code&#xff0c;但是前面的数据整理…

把图片存成视频 python

tips: 1.保存的图片大小一定要一样 2.图像做好是标准的视频格式大小 3.图片要和视频size一样大小 代码如下 # -*- coding:utf8 -*- import os import cv2 import numpy as np import cv2.cv as cv path /home/m/mycode/cv filelist os.listdir(path) total_num len(f…

sdut 双向队列(STL)

deque<ll>q;//定义一个双向队列q&#xff0c;类型为long long q.push_front(a);//将a从队首插入队列 q.push_back(a);//将a从队尾插入队列 q.pop_front();//队首弹掉一个元素 q.pop_back();//队尾弹出一个元素 aq.front();//返回队首元素 aq.back();//返回队尾元素 aq.si…

给文件重命名

# -*- coding:utf8 -*-import osclass BatchRename():批量重命名文件夹中的图片文件def __init__(self):self.path home/l/imagedef rename(self):filelist os.listdir(self.path)total_num len(filelist)i 0for item in filelist:if item.endswith(.jpg):src os.path.joi…

pip install scikit-image on windows 失败 解决方案

到官网下载包 http://www.lfd.uci.edu/~gohlke/pythonlibs/#scikit-image 我们下载 scikit_image‑0.13.0‑cp35‑cp35m‑win_amd64.whl 也可到我的CNDS下载 安装时会出现一下错误 scikit_image-0.13.0-cp34-none-win_amd64.whl is not a supported wheel on this platform…

sdut 数据结构实验之排序三:bucket sort

一开始这种做法超时&#xff1a; #include<stdio.h>int b[5000000],a[5000000],n,ans; void merge_sort(int *a,int *b,int x,int y) {if(y-x>1){int mx(y-x)/2;//中间点的坐标int px,qm,ix;merge_sort(a,b,x,m);merge_sort(a,b,m,y);while(p<m||q<y){if(q>…

Caffe训练源码基本流程

苏的专栏 致力于学习计算机视觉、模式识别、机器学习、深度学习相关技术&#xff1a;&#xff1a;&#xff1a;&#xff1a;希望结识更多同道中人。 QQ&#xff1a;2816568984 微信&#xff1a;Suc1011 目录视图 摘要视图 订阅 【活动】2017 CSDN博客专栏评选 【评论送书】…

fatal error: GL/glew.h: 没有那个文件或目录

搜索libglew的版本 #apt-cache search glew libglew-dbg - OpenGL Extension Wrangler (debugging symbols) libglew-dev - OpenGL Extension Wrangler - development environment libglew1.13 - OpenGL Extension Wrangler - runtime environment libglewmx-dbg - OpenGL E…

运行cudasift

文件中有cmakelist.txt 运行命令 cmake . 就会生成makefile type: make 出现错误&#xff1a; /usr/bin/ld: 找不到 -lopencv_dep_cudart 在cmake 时候用一下指令&#xff1a; cmake -D CUDA_USE_STATIC_CUDA_RUNTIMEOFF . make的时候可能会出现以下错误 make[2]: …

电脑DNS修复

首先在dos窗口下输入以下命令&#xff1a; ipconfig/displaydns 可以看到当前的缓存的所有DNS记录&#xff1a; 然后&#xff1a; ipconfig/flushdns 刷新当前的DNS

数据结构实验之排序七:选课名单(卡内存的一道题。。坑)

RE。。。 带更正 #include<iostream> #include<algorithm> using namespace std; #include<cstdio> #include<cstring> struct people {char name[100];int sum_class;int cl[2005]; }a[40000],b[40000]; int cmp(people a,people b) {char t[100],l[…