c++ builder 中的 XMLDocument 类详解(13) - 遍历XML文件

简介: //--------------------------------------------------------------------------- #ifndef Unit1H #define Unit1H //-----------------------------------...
//---------------------------------------------------------------------------

#ifndef Unit1H
#define Unit1H
//---------------------------------------------------------------------------
#include <Classes.hpp>
#include <Controls.hpp>
#include <StdCtrls.hpp>
#include <Forms.hpp>
#include <msxmldom.hpp>
#include <XMLDoc.hpp>
#include <xmldom.hpp>
#include <XMLIntf.hpp>
//---------------------------------------------------------------------------
class TForm1 : public TForm
{
__published:	// IDE-managed Components
    TButton *btn_1;
    TButton *btn_2;
    TXMLDocument *XMLDocument1;
    void __fastcall btn_1Click(TObject *Sender);
private:	// User declarations
public:		// User declarations
    __fastcall TForm1(TComponent* Owner);
};
//---------------------------------------------------------------------------
extern PACKAGE TForm1 *Form1;
//---------------------------------------------------------------------------
#endif
//---------------------------------------------------------------------------

#include <vcl.h>
#pragma hdrstop

#include "Unit1.h"
#include <stdio.h>
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
    : TForm(Owner)
{
}
//---------------------------------------------------------------------------

String ReadXml(_di_IXMLNode node)
{
    _di_IXMLNodeList nodeList,attrList;

    String str,strName,strValue,result;
    int i;
    if(!node->HasChildNodes)
        return "";
    attrList=node->AttributeNodes;//根节点属性列表
    nodeList=node->ChildNodes;  //根节点下的子节点列表

    str="<"+node->NodeName;

    //先读取属性
    for(int i=0;i<attrList->Count-1;i++)
    {
        strName=attrList->Nodes[i]->Text;//结点名字
        strValue=attrList->Nodes[i]->Text; //结点值
        str=str+" "+strName+"="+AnsiQuotedStr(strValue,'\"');//AnsiQuotedStr定界符函数
    }
    str=str+">"+sLineBreak;//sLineBreak是常量
    //读取子结点

    for(int i=0;i<nodeList->Count;i++)
    {
        if(nodeList->Nodes[i]->IsTextElement)//如果他是文本结点则读它的数据
        {
            strName=nodeList->Nodes[i]->NodeValue;//结点值
            str=str+"<"+strName+">"+strValue+"</"+strName+">"+sLineBreak;
        }
        else if(nodeList->Nodes[i]->HasChildNodes)//如果是不是文本结点而且有子结点
        {
            str=str+ReadXml(nodeList->Nodes[i]);
            str=str+"</"+strName+">"+sLineBreak;
        }
    }
    str=str+"</"+node->NodeName+">";//封口
    return str;
}



//调用测试
void __fastcall TForm1::btn_1Click(TObject *Sender)
{
    String str_an,s1,s2;
    char str[50];

    XMLDocument1->LoadFromFile("D:\\code\\B_C_B\\XMLDocument\\test.xml");

    //读取文件
    s1=AnsiQuotedStr(XMLDocument1->Version,'"');//读出版本, 并添加双引号
    s2=AnsiQuotedStr(XMLDocument1->Encoding,'"');//读出字符集, 并添加双引号
//    str=Format("<?xml version=%s encoding=%s?>",s1,s2,2);//
    sprintf(str,"<?xml version=%s encoding=%s?>",s1,s2);// 这就是头文件了
    str_an=AnsiString(str);
    str_an=str_an+sLineBreak+ReadXml(XMLDocument1->DocumentElement);
    ShowMessage(str_an);//返回
}
//---------------------------------------------------------------------------
相关文章
|
8月前
|
C++ Windows
.NET Framework安装不成功,下载`NET Framework 3.5`文件,Microsoft Visual C++
.NET Framework常见问题及解决方案汇总,涵盖缺失组件、安装失败、错误代码等,提供多种修复方法,包括全能王DLL修复工具、微软官方运行库及命令行安装等,适用于Windows系统,解决应用程序无法运行问题。
1181 3
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
611 3
|
存储 算法 安全
基于哈希表的文件共享平台 C++ 算法实现与分析
在数字化时代,文件共享平台不可或缺。本文探讨哈希表在文件共享中的应用,包括原理、优势及C++实现。哈希表通过键值对快速访问文件元数据(如文件名、大小、位置等),查找时间复杂度为O(1),显著提升查找速度和用户体验。代码示例展示了文件上传和搜索功能,实际应用中需解决哈希冲突、动态扩容和线程安全等问题,以优化性能。
|
数据采集 存储 算法
【C++数据结构——图】图的遍历(头歌教学实验平台习题) 【合集】
本文介绍了图的遍历算法,包括深度优先遍历(DFS)和广度优先遍历(BFS)。深度优先遍历通过递归方式从起始节点深入探索图,适用于寻找路径、拓扑排序等场景;广度优先遍历则按层次逐层访问节点,适合无权图最短路径和网络爬虫等应用。文中提供了C++代码示例,演示了如何实现这两种遍历方法,并附有测试用例及结果,帮助读者理解和实践图的遍历算法。
764 0
|
Linux C++
Linux c/c++文件的基本操作
在Linux环境下使用C/C++进行文件的基本操作,包括文件的创建、写入、读取、关闭以及文件描述符的定位。
259 0
Linux c/c++文件的基本操作
|
C++ 内存技术
[转]Visual C++内嵌swf文件并播放
[转]Visual C++内嵌swf文件并播放
|
Linux C++
Linux c/c++文件虚拟内存映射
这篇文章介绍了在Linux环境下,如何使用虚拟内存映射技术来提高文件读写的速度,并通过C/C++代码示例展示了文件映射的整个流程。
487 0
|
Linux C++
Linux c/c++文件移动
这篇文章介绍了在Linux环境下,使用C/C++语言通过命令方式和文件操作方式实现文件移动的方法。
394 0
|
Linux API C++
超级好用的C++实用库之文件目录操作
超级好用的C++实用库之文件目录操作
283 0
|
JavaScript 前端开发 测试技术
一个google Test文件C++语言案例
这篇文章我们来介绍一下真正的C++语言如何用GTest来实现单元测试。
206 0