前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Delphi使用NativeXml处理XML(一)

Delphi使用NativeXml处理XML(一)

作者头像
Vaccae
发布于 2019-07-25 03:26:19
发布于 2019-07-25 03:26:19
1.1K00
代码可运行
举报
文章被收录于专栏:微卡智享微卡智享
运行总次数:0
代码可运行

前言

  本帮助文件提供从SimDesign BV的NativeXml组件的信息。

使用NativeXml的例子


3.1.例子A:XML的装载、存储和导出   这个例子显示如何加载一个XML文档,然后以可读格式导出到一个TMemo领域。   拖放一个TEdit(Edit1),TButton(Button1)和一个TMemo到你的窗体,然后连接到下面的按钮的OnClick事件代码。填写文件名到Edit1,然后按一下按钮,您会看到在memo控件中列出XML文件的内容。

代码语言:javascript
代码运行次数:0
运行
复制
procedure TForm1.Button1Click(Sender: TObject);
var
     ADoc: TNativeXml;
begin
     Memo1.Lines.Clear;
     ADoc := TNativeXml.Create;
     try
        ADoc.LoadFromFile(Edit1.Text);
        ADoc.XmlFormat := xfReadable;
        Memo1.Lines.Text := ADoc.WriteToString;
     finally
        ADoc.Free;
     end;
end;

  注意,ADoc.XmlFormat:= xfReadable将确保该文件是以易读的形式列出(以回车符和缩进)。


3.2.例子B:连接到节点   这个例子显示了如何访问在XML文件中的各个节点。一个节点可以从一个普通的XML标记、注释、CDATA结构,等等东西。该示例演示如何使用一个简单的双循环列出前2层的节点。   添加Tedit、TButton和TMemo到窗体,然后将下面的事件代码连接到按钮的OnClick。然后在Edit1中填写文件名,按一下按钮,前两层的节点将会在memo控件中列出。

代码语言:javascript
代码运行次数:0
运行
复制
procedure TForm1.Button2Click(Sender: TObject);
var
     i, j: integer;
     ADoc: TNativeXml;
begin
     Memo1.Lines.Clear;
     ADoc := TNativeXml.Create;
     try
       ADoc.LoadFromFile(Edit1.Text);
       if assigned(ADoc.Root) then with ADoc.Root do
         for i := 0 to NodeCount - 1 do begin
          Memo1.Lines.Add(Nodes[i].Name);
           for j := 0 to Nodes[i].NodeCount - 1 do
             Memo1.Lines.Add(' ' + Nodes[i].Nodes[j].Name);
         end;
    finally
       ADoc.Free;
    end;
end;

3.3.例子C:事件驱动处理   这个例子说明了NativeXml可以用一个SAX-like的方式,按顺序读文件,每当一个节点初始化和加载时产生事件。   添加一个TButton(Button3)和一个TMemo(Memo1)到您的窗体,然后将NativeXml包括在uses中。接下来,键入下面的TButton.OnClick事件处理程序代码。

代码语言:javascript
代码运行次数:0
运行
复制
procedure TForm1.Button3Click(Sender: TObject);
var
     ADoc: TNativeXml;
begin
     Memo1.Lines.Clear;
     ADoc := TNativeXml.Create;
     try
       ADoc.OnNodeNew    := DoNodeNew;
       ADoc.OnNodeLoaded := DoNodeLoaded;
       ADoc.LoadFromFile(Edit1.Text);
     finally
       ADoc.Free;
     end;
end;

键入下面的程序代码在新的TForm1中:

代码语言:javascript
代码运行次数:0
运行
复制
function TForm1.Indent(ACount: integer): string;
begin
     while ACount > 0 do begin
       Result := Result + '  ';
       dec(ACount);
     end;
end;
procedure TForm1.DoNodeNew(Sender: TObject; Node: TXmlNode);
begin
     Memo1.Lines.Add(Format('New : %sName=%s', [Indent(Node.TreeDepth),    Node.Name]));
end;
procedure TForm1.DoNodeLoaded(Sender: TObject; Node: TXmlNode);
begin
     Memo1.Lines.Add(Format('Loaded: %sName=%s, Value=%s', [In   dent(Node.TreeDepth), Node.Name, Node.ValueAsString]));
end;

当一个节点被找到,OnNodeNew事件被触发,每当一个节点完全装载,OnNodeLoaded事件被触发。   如果您不希望保留在内存中的XML文件的完整副本,例如,对大型XML文件,你可以直接删除该节点,释放其内存。在这种情况下,添加以下代码到OnNodeLoaded事件:

代码语言:javascript
代码运行次数:0
运行
复制
procedure TForm1.DoNodeLoaded(Sender: TObject; Node: TXmlNode);
begin
     Memo1.Lines.Add(Format('Loaded: Name=%s, Value=%s', [Node.Name,   Node.ValueAsString]));
     if Node.TreeDepth > 0 then begin
       Memo1.Lines.Add(Format('Deleted: Name=%s', [Node.Name]));
       Node.Delete;
     end;
end;

3.4.例子D:创建一个简单的XML文件   这个例子演示如何创建一个简单的XML文件,在根节点下的一个节点,有一个属性和子节点。我们将尝试创建这个XML文件:

代码语言:javascript
代码运行次数:0
运行
复制
<?xml version="1.0" encoding="windows-1252"?>
<Root>
  <Customer ID="123456">
    <Name>John Doe</Name>
  </Customer>
</Root>

  下面是一个过程的代码,创建此文件,并以易读格式保存到一个文件名为“C:\test.xml”的文件:

代码语言:javascript
代码运行次数:0
运行
复制
procedure CreateXML;
var
     ADoc: TNativeXml;
begin
     // Create new document with a rootnode called "Root"
     ADoc := TNativeXml.CreateName('Root');
     try
     // Add a subnode with name "Customer"
       with ADoc.Root.NodeNew('Customer') do begin
         // Add an attribute to this subnode
         WriteAttributeInteger('ID', 123456);
         // Add subsubnode
         WriteString('Name', 'John Doe');
       end;

      // Save the XML in readable format (so with indents)
       ADoc.XmlFormat := xfReadable;
       // Save results to a file
       ADoc.SaveToFile('c:\test.xml');
     finally
       ADoc.Free;
     end;
end;

3.5.例子E:使用UTF8和Unicode编码的文件(支持widestring)   这个例子显示了如何创建和加载支持widestrings的XML文件。 3.5.1.NativeXml内部编码   NativeXml可以工作在两种“模式”:要么所有的内部字符串是普通的ANSI字符串或所有内部字符串是UTF8编码字符串。字符串类型不会改变(它仍然是“string”)。虽然Delphi7有一种特殊类型“Utf8String”,但没有使用,以保持较低的Delphi版本的兼容性。   为了确保你的XML文档可以使用widestrings,创建它,然后直接设置属性“Utf8Encoded”为True,如下所示:

代码语言:javascript
代码运行次数:0
运行
复制
 procedure CreateXML;
var
     ADoc: TNativeXml;
begin
     ADoc := TNativeXml.CreateName('Root');
     try
       // Make sure to be able to handle widestrings
       ADoc.Utf8Encoded := True;
       // ..add all your creation code here
     finally
       ADoc.Free;
     end;
end;

3.5.2.NativeXml外部编码   保存您的文档时,为外部文件或流选择适当的编码(SaveToStream也需要正确的编码保存)。设置属性“ExternalEncoding”到其中的任何值: se8bit:这将返回一个纯ASCII文件,所有的Unicode/widestring字符值高于$FF。这是默认值。 seUTF16LE:这将返回一个Unicode文件的字节顺序标记$FF FE。这应该作为一个Unicode文件的默认。 seUTF16BE:这将返回大字节(big-endian)Unicode文件的字节顺序标记$FE FF。 seUTF8:这将返回一个UTF-8编码文件的字节顺序标记$FF BB BF。UTF-8在大部分字符为西方或拉丁语时,是更好的存储方式。然而,它可以为中文或日文等多种语言提供更多的空间。   这里有一个关于如何设置外部编码的例子:

代码语言:javascript
代码运行次数:0
运行
复制
procedure CreateXML;
var
     ADoc: TNativeXml;
begin
     ADoc := TNativeXml.CreateName('Root');
     try
       // Make sure to be able to handle widestrings
       ADoc.Utf8Encoded := True;

      // ..add all your creation code here
      // Save to unicode
       ADoc.ExternalEncoding := seUTF16LE;
       ADoc.EncodingString := 'UTF-16';
       ADoc.SaveToFile('c:\temp\test.xml');    
     finally
       ADoc.Free;
     end;
end;

3.5.3.添加widestrings   添加widestrings到文档很容易。每个节点的值可以设置为widestring,使用属性的ValueAsWidestring,并可以在一般情况下使用FromWidestring函数添加widestrings。   下面的例子代码,增加了一个新的节点到根,然后设置节点名字(Name)为Aname,节点值(value)为AValue:

代码语言:javascript
代码运行次数:0
运行
复制
procedure AddNode(ADoc: TXmlDocument; AName, AValue: widestring);
begin
  with ADoc.Root do
    with NodeNew(FromWidestring(AName)) do
      ValueAsWidestring := AValue;
end;

3.5.4.加载XML文件的扩展字符   当读取包含扩展字符的XML文件,重要的是在引入前设置Utf8Encoded为True,像这样:

代码语言:javascript
代码运行次数:0
运行
复制
function CreateXMLAndLoadFromFile(AFilename: string): TNativeXml;
begin
     Result := TNativeXml.Create;
     Result.Utf8Encoded := True;
     Result.LoadFromFile(AFilename);  
end;

  当从一个流(例如从一个TCP连接)读入,流并不总是包含字节顺序标记(BOM)。但是,如果流是Unicode,NativeXml将承认它,因此没有任何帮助。例如:

代码语言:javascript
代码运行次数:0
运行
复制
function CreateXMLAndLoadFromStream(S: TStream): TNativeXml;
begin
     Result := TNativeXml.Create;
     Result.Utf8Encoded := True;
     Result.LoadFromStream(S);  
end;

  如果你知道你的流具有一定的编码,你可以强制NativeXml使用这种编码,例如:

代码语言:javascript
代码运行次数:0
运行
复制
function CreateXMLAndLoadFromUTF8Stream(S: TStream): TNativeXml;
begin
     Result := TNativeXml.Create;
     Result.Utf8Encoded := True;
     // The stream is encoded using UTF8
     Result.ExternalEncoding := seUTF8;
     Result.LoadFromStream(S);  
end;

-END-

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-07-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微卡智享 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
Delphi使用NativeXml处理XML(二)
4.1.类(Classes) 4.1.1.TComponentAccess类   TComponentAccess = class(TComponent) 4.1.1.1.ComponentState   property ComponentState; 4.1.1.2.SetComponentState   procedure SetComponentState(const AState: TComponentState); 4.1.2.TNativeXml类   TNativeXml = class(TPersistent)   TNativeXml是XML文件的载体。创建一个TNativeXml,然后使用方法LoadFromFile、LoadFromStream或ReadFromString加载XML文档到内存中。或者从头开始使用Root.NodeNew添加节点,并最终SaveToFile和SaveToStream保存结果为一个XML文档。用属性Xmlformat = xfReadable确保缩进(易读)输出。 4.1.2.1.AbortParsing   property AbortParsing: boolean;   如果您使用一个SAX-like方式的OnNodeNew和OnNodeLoaded事件,并要中止解析过程,设置AbortParsing为True。例如:
Vaccae
2019/07/25
1.5K0
[重点]delphi 实现 根据给定的标题去《中国青年报》网上电子报数据中查找匹配的内容,并从该内容中取出引题、正题、副题、作者和正文。
项目要求:根据给定的标题去《中国青年报》网上电子报数据中查找匹配的内容,并从该内容中取出引题、正题、作者和正文。
全栈程序员站长
2022/09/07
7210
delphi枚举wmi
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs,SiMath,SimEncrypt, StdCtrls,ActiveX,ComObj,JwaWbemCli; type TForm1 = class(TForm) Button1: TButton; Memo: TMemo; Button2: TB
战神伽罗
2019/07/24
2.1K0
Python For Delphi---
svn checkout http://python4delphi.googlecode.com/svn/trunk/ python4delphi-read-only
py3study
2020/01/10
2.8K0
计算器(delphi)
1 unit Unit1; 2 3 interface 4 5 uses 6 Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, 7 Dialogs, StdCtrls, bsSkinData, BusinessSkinForm, Mask, bsSkinBoxCtrls, bscalc, 8 bsSkinCtrls; 9 10 type 11
小爷毛毛_卓寿杰
2019/02/13
3K0
delphixe5 android,Delphi XE5 Android手机端转换Ansi字符串
本文章介绍了Delphi XE5 Android手机端转换Ansi字符串,本代码是“浙江-樵夫”开发的一个程序,用来对字符串进行转换,主要代码是:
全栈程序员站长
2022/09/09
3470
奖学金评分系统(系统分析与设计版与Delphi实现代码)
在奖学金评比过程中,学生综合测评是学校普遍采用的评比手段。对学生实施综合素质测评的目的在于正确评价学生的综合素质,为评奖学金提供依据,实现学生教育管理工作的标准化、制度化和科学化,引导和促进学生德、智、体、美全面发展。
小爷毛毛_卓寿杰
2019/02/13
9580
奖学金评分系统(系统分析与设计版与Delphi实现代码)
学习笔记:7z在delphi的应用
最近做个发邮件的功能,需要将日志文件通过邮件发送回来用于分析,但是日志文件可能会超级大,测算下来一天可能会有800M的大小。所以压缩是不可避免了,delphi中的默认压缩算法整了半天不太好使,就看了看7z,在windows下有dll那么就用它吧。 下载7z.dll,还有一个delphi的开发sdk文件,sevenzip.pas。有这两个就可以了。 压缩 使用超级简单 procedure TForm1.Button1Click(Sender: TObject); var Arch: I7zOutArchi
用户1105954
2018/01/12
2.7K1
FTP my IP
程序功能,获取主机ip然后上传到指定的ftp,检测时间间隔每30min。程序源代码编译即可直接运行。
obaby
2023/02/28
2480
Delphi使用NativeXml处理XML(四)
4.2.1.ComponentCreateFromXmlFile   unit NativeXmlObjectStorage   function ComponentCreateFromXmlFile(const FileName: string; Owner: TComponent; const Name: string): TComponent;   从文件名称为FileName的XML文件读取并创建组件。为了成功地从头开始创建组件,组件的类必须事先调用RegisterClass进行登记。添加到指定Owner组件的子组件列表。这通常是一个形式。指定Name作为创建的组件的新组件的名称。 注:它调用ComponentCreateFromXmlStream实现。 4.2.2.ComponentCreateFromXmlNode   function ComponentCreateFromXmlNode(ANode: TXmlNode; Owner: TComponent; const Name: string): TComponent;   从TXmlNode类型的ANode节点读取并创建组件。为了成功地从头开始创建组件,组件的类必须事先调用RegisterClass进行登记。添加到指定Owner组件的子组件列表。这通常是一个形式。指定Name作为创建的组件的新组件的名称。 注:它使用TsdXmlObjectReader类实现。 4.2.3.ComponentCreateFromXmlStream   function ComponentCreateFromXmlStream(S: TStream; Owner: TComponent; const Name: string): TComponent;   从XML流类型的S中读取并创建组件。为了成功地从头开始创建组件,组件的类必须事先调用RegisterClass进行登记。添加到指定Owner组件的子组件列表。这通常是一个形式。指定Name作为创建的组件的新组件的名称。 注:它调用ComponentCreateFromXmlNode实现。 4.2.4.ComponentCreateFromXmlString   function ComponentCreateFromXmlString(const Value: string; Owner: TComponent; const Name: string): TComponent;   从XML字符串类型的Value中读取并创建组件。为了成功地从头开始创建组件,组件的类必须事先调用RegisterClass进行登记。添加到指定Owner组件的子组件列表。这通常是一个形式。指定Name作为创建的组件的新组件的名称。 注:它调用ComponentCreateFromXmlStream实现。 4.2.5.ComponentSaveToXmlFile   procedure ComponentSaveToXmlFile(AComponent: TComponent; const FileName: string; AParent: TComponent);   存储组件AComponent所有公布的属性到名为FileName 的XML文件。指定AParent为了储存Parent正确的方法和事件参考。 注:它调用ObjectSaveToXmlFile实现。 4.2.6.ComponentSaveToXmlNode   procedure ComponentSaveToXmlNode(AComponent: TComponent; ANode: TXmlNode; AParent: TComponent);   存储组件AComponent所有公布的属性到TXmlNode格式的ANode中。指定AParent为了储存Parent正确的方法和事件参考。 注:它调用ObjectSaveToXmlNode实现。 4.2.7.ComponentSaveToXmlStream   procedure ComponentSaveToXmlStream(AComponent: TComponent; S: TStream; AParent: TComponent);   存储组件AComponent所有公布的属性到XML格式的流S中。指定AParent为了储存Parent正确的方法和事件参考。 注:它调用ObjectSaveToXmlStream实现。 4.2.8.ComponentSaveToXmlString   function ComponentSaveToXmlString(AComponent: TComponent; AParent: TComponent): string;   存储组件AComponent所有公布的属
Vaccae
2019/07/24
1.9K0
Delphi中使用RTTI
运行期类型信息(RTTI)是一种语言特征,能使应用程序在运行时得到关于对象的信息。
Vaccae
2019/07/24
2K0
.NET 2.0 Web Services的bug?
今天测试.net 2.0的WebService,发现了一个大问题。就是无法获取参数,参数永远是null。当然了使用.net调用没有任何问题,web测试页也正常。不论是Delphi7还是java调用的结果的都是一样的,难道是.net 2.0的Bug? 测试结果发现:值类型参数全部为缺省值,引用类型全部为null WebService的代码如下:
用户3135539
2018/09/12
6510
raw socket (DELPHI开发平台)
下面给出一个通过自定义源IP地址和源端口演示如何发送UDP数据包的例子,或许对你了解有所帮助.你也可以设计自己的协议,如发送SY N 数据浪涌,或其它类型的自定义协议。 { Raw 数据包 Sender 使用:Delphi + Winsock 2
战神伽罗
2019/09/02
6970
delphi 使用windowsmediaplayer播放视频
delphi7中原本自带的一个Tmediaplayer控件,但是发现有不少视频是无法播放的,于是就想到了用windowsmediaplayer来进行播放。
Vaccae
2019/07/25
3.1K0
delphi 使用windowsmediaplayer播放视频
【Delphi】 Thread.Queue与Synchronize的区别
前话: 其实大家要学会看源码, 我接下来要说的这些东东,与其等别人讲,还不如自己搞几个代码试一下,印象还深刻点 TThread.Queue和TThread.Synchronize的区别,
战神伽罗
2019/07/24
1.9K0
delphi完美的线程注入和卸载
uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls;
战神伽罗
2019/07/24
1K0
蛋疼的挂掉360云查杀的小玩意儿
其实就是个域名屏蔽的列表,做个小工具便于免杀。没什么高深的技术。 最后蛋疼的贴点代码: procedure TForm1.FormCreate(Sender: TObject); begin GetSystemDirectory(sysdir,256); hosts := sysdir + '\drivers\etc\hosts'; backup := sysdir + '\drivers\etc\hosts.bak'; //ShowMessage(hosts); if FileExists(hosts
obaby
2023/02/28
3410
蛋疼的挂掉360云查杀的小玩意儿
截取程序的网络封包(Delphi Hook API)
有时候我们需要对其它应用程序发送和接收的网络数据进行拦截,比如要对IE发送的**头进行分析,得到请求的地址等.这次我们可以用一些例如WPE, Sniffer之类的工具来达到目的.但是工具功能有限,要想实现更强大的功能,还是我们自己动手来DIY吧. 拦截网络数据封包的方法有三种,一是将网卡设为混杂模式,这次就可以监视到局域网上所有的数据包,二是HOOK目标进程的发送和接收的API函数,第三种方法是自己实现一个代理的DLL.在这里我们使用HOOK API的方法,这样易于实现,而且也不会得到大量的无用数据(如第一种方法就会监视到所有的网络数据). 下面是一个尽量简化了的API HOOK的模版,原理是利用消息钩子将DLL中的代码注入到目标进程中,再用GetProcAddress得到API函数入口地址,将函数入口址改为自己定义的函数入口,这样就得到了API函数的相应参数,处理完后,再改回真实API函数入口地址,并调用它. HOOK.DLL的代码:
战神伽罗
2019/07/24
1.9K0
截取程序的网络封包(Delphi Hook API)
数组类型与数组指针的巧妙利用
本例通过存取结构, 慢慢引入了数组类型与指针的一些使用方法; 其中六个小例子的测试内容和结果都是一样的.
Vaccae
2019/07/24
8400
学习笔记:delphi多线程知识
最近一直在温习旧的知识,刚好学习了一下Java的线程安全方面的知识,今天想起之前一直做的Delphi开发,所以还是有必要温习一下,看看这些不同的编程语言有什么不同之处。 Delphi的线程同步方法: 1、临界区 申明一个临界资源 FLock   : TRTLCriticalSection; 先初化一个临界资源对象 InitializeCriticalSection(FLock) 销毁临界资源对象 DeleteCriticalSection(FLock) procedure TSaveThread.Push
用户1105954
2018/01/12
1.2K0
相关推荐
Delphi使用NativeXml处理XML(二)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档