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月前
|
Android开发 开发者
Android自定义View之不得不知道的文件attrs.xml(自定义属性)
本文详细介绍了如何通过自定义 `attrs.xml` 文件实现 Android 自定义 View 的属性配置。以一个包含 TextView 和 ImageView 的 DemoView 为例,讲解了如何使用自定义属性动态改变文字内容和控制图片显示隐藏。同时,通过设置布尔值和点击事件,实现了图片状态的切换功能。代码中展示了如何在构造函数中解析自定义属性,并通过方法 `setSetting0n` 和 `setbackeguang` 实现功能逻辑的优化与封装。此示例帮助开发者更好地理解自定义 View 的开发流程与 attrs.xml 的实际应用。
239 2
Android自定义View之不得不知道的文件attrs.xml(自定义属性)
|
XML 前端开发 Java
讲解SSM的xml文件
本文详细介绍了SSM框架中的xml配置文件,包括springMVC.xml和applicationContext.xml,涉及组件扫描、数据源配置、事务管理、MyBatis集成以及Spring MVC的视图解析器配置。
305 1
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
578 3
|
Java Maven
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
1073 8
|
数据采集 存储 算法
【C++数据结构——图】图的遍历(头歌教学实验平台习题) 【合集】
本文介绍了图的遍历算法,包括深度优先遍历(DFS)和广度优先遍历(BFS)。深度优先遍历通过递归方式从起始节点深入探索图,适用于寻找路径、拓扑排序等场景;广度优先遍历则按层次逐层访问节点,适合无权图最短路径和网络爬虫等应用。文中提供了C++代码示例,演示了如何实现这两种遍历方法,并附有测试用例及结果,帮助读者理解和实践图的遍历算法。
722 0
|
XML Android开发 数据格式
Eclipse 创建 XML 文件
Eclipse 创建 XML 文件
220 2
|
XML JavaScript 数据格式
XML DOM 遍历节点树
XML DOM 遍历节点树
|
XML JavaScript 数据格式
XML DOM 遍历节点树
XML DOM 遍历节点树
|
XML JavaScript Java
java与XML文件的读写
java与XML文件的读写
168 3
|
XML JavaScript 数据格式
XML DOM 遍历节点树
XML DOM 遍历节点树