XMLDocument;

Xml.XMLIntf.hpp

Xml.XMLDoc.hpp

#include "Xml.Win.msxmldom.hpp"

XMLDocument控件

Winapi.msxmlIntf.pas

selectsinglenode只返回一个结点
 SelectNodes返回多个匹配的结点

DOM解析器的3种选择

MSXML MS Windows/Omni

解析器的选择

Xml.XMLDoc.TXMLDocument.DOMVendor

http://docwiki.embarcadero.com/CodeExamples/Seattle/e/index.php?title=Category:C%2B%2B&pagefrom=SystemVarClear+%28C%2B%2B%29#mw-pages

void CreateDocument() {
_di_IXMLDocument document = interface_cast<Xmlintf::IXMLDocument>
(new TXMLDocument(NULL));
document->Active = true; // Define document content.
document->DocumentElement = document->CreateNode("ThisIsTheDocumentElement",
ntElement, "");
document->DocumentElement->Attributes["attrName"] = "attrValue";
_di_IXMLNode nodeElement = document->DocumentElement->AddChild
("ThisElementHasText", -);
nodeElement->Text = "Inner text.";
_di_IXMLNode nodeCData = document->CreateNode("any characters here",
ntCData, "");
document->DocumentElement->ChildNodes->Add(nodeCData);
_di_IXMLNode nodeText = document->CreateNode("This is a text node.",
ntText, "");
document->DocumentElement->ChildNodes->Add(nodeText); document->SaveToFile(destPath);
}

生成文件

http://overblue.blogbus.com/logs/13954596.html

uses
XMLDoc, XMLIntf; { 写入XML内容 }
var
XMLDoc : TXMLDocument;
Node1 : IXMLNode;
Node2 : IXMLNode;
begin
XMLDoc := TXMLDocument.Create(nil);
try
XMLDoc.Active := True;
XMLDoc.Version := '1.0';
XMLDoc.Encoding := 'GB2312';
XMLDoc.Options := [doNodeAutoCreate,doNodeAutoIndent,doAttrNull,doAutoPrefix,doNamespaceDecl]; XMLDoc.DocumentElement := XMLDoc.CreateNode('ReportObjectContent');
Node1 := XMLDoc.DocumentElement; Node1 := Node1.AddChild('ReportObjectProperty');
Node2 := Node1.AddChild('ReportName');
Node2.SetAttributeNS('Value', '', ReportName);
Node2 := Node1.AddChild('ReportType');
Node2.SetAttributeNS('Value', '', ReportType);
Node2 := Node1.AddChild('DataViewName');
Node2.SetAttributeNS('Value', '', DataViewName);
Node2 := Node1.AddChild('SQLStr');
Node2.SetAttributeNS('Value', '', SQLStr); XMLDoc.SaveToStream(Stream);
finally
XMLDoc.Free;
end;

XMLDocument1.DOMDocument.childNodes['Config'].attributes['DataUpFlag'];

xml->DocumentElement->AddChild("TableClassName")->Text = aClassName;
xml->DocumentElement->AddChild("ApplicationName")->NodeValue = LabeledEdit5->Text;

if (node->ChildNodes->Get(i)->NodeType() == ntElement)

读解析文件

LoadFromFile

LoadXMLData 读XML字符串

DocumentElement
    _di_IXMLNode snode = XMLDocument1->DocumentElement->ChildNodes->Nodes("row");

__property _di_IXMLNode Nodes[System::OleVariant IndexOrName] = {read=GetNode/*, default*/};
    XMLDocument1->LoadFromFile(lxml);
_di_IXMLNode snode = XMLDocument1->DocumentElement->ChildNodes->FindNode(aTableName);
if (snode)
{
for (int i = ; i < snode->ChildNodes->Count; i++)
{
_di_IXMLNode rownode = snode->ChildNodes->Get(i); String fn = rownode->Attributes["Field"];
} }
XMLDocument1->Active = false;

增加或修改节点

xml->CreateElement
xml->CreateNode

xml->DocumentElement->AddChild
    _di_IXMLNode nodeElement = xml->DocumentElement->ChildNodes->FindNode("DAOPath");
if (nodeElement == NULL)
nodeElement = xml->DocumentElement->AddChild("DAOPath");
nodeElement->Text = DaoPath;

缩进,格式化

XMLDocument1->Options = XMLDocument1->Options << doNodeAutoIndent;

<?xml version="1.0" encoding="utf-8"?>
<data>
<config>
<recent>aaa</recent>
</config>
<list>
<row name="aa" port=""></row>
<row name="bb" port=""></row>
</list>
</data>

读取recent的值

fangA = XMLDocument1->DocumentElement->ChildNodes->FindNode("config")->ChildNodes->FindNode("recent")->NodeValue;

XMLDocument1->DocumentElement->ChildNodes->FindNode("config")->ChildNodes->FindNode("recent")->NodeValue="newstring";

 XmlDocument1.DocumentElement.ChildNodes[0];
Node := XmlDocument1.DocumentElement.ChildNodes[0]; // <Class> node
Node.ChildNodes.Add(LoadXMLData('<Property Name="Version" RttiType="tkString"></Property>').DocumentElement);
Node.ChildNodes.Add(LoadXMLData('<Property Name="ShowSubunit" RttiType="tkBoolean"></Property>').DocumentElement);
xml.DocumentElement.ChildNodes.FindNode('data').DOMNode.ownerDocument.importNode()

IDOMDocument
    xml.DOMDocument.appendChild()
    xml.DOMDocument.importNode()   XMLDocument1.DocumentElement.ChildNodes.FindNode('').OwnerDocument.importNode//IXMLDocument没有此方法
  XMLDocument1.DocumentElement.ChildNodes.FindNode('').DOMNode.ownerDocument.importNode()//IDOMDocument有次方法
     node:= XMLDocument1.DocumentElement.ChildNodes.Nodes[i];
     node.ChildNodes.FindNode('nodename') var
node:IXMLNode; XMLDocument1.XML.Text;//包含version
XMLDocument1.DocumentElement.Xml//根节点下的字符串
XMLDocument1.DocumentElement.Text 2、读取文件
LoadXMLDocument
Xml.XMLDoc
#include <Xml.XMLIntf.hpp>
IXMLDocument doc:=LoadXMLDocument('abc.xml');
_di_IXMLDocument doc=LoadXMLData("xmlstring");

_di_IXMLDocument doc=LoadXMLDocument("aa.xml");
doc->DocumentElement->ChildNodes->FindNode("jgbm")->NodeValue;
doc->DocumentElement->ChildNodes->FindNode("para")->Attributes["pw"]; 官方的解释是会自动释放!这样就不用创建控件了。TXMLDocument
 http://docwiki.embarcadero.com/RADStudio/Berlin/en/XML_Support_Routines
http://docwiki.embarcadero.com/Libraries/Berlin/en/Xml.XMLDoc.LoadXMLDocument

Returns the interface for an XML document given the name of an XML file.

Call LoadXMLDocument to load an XML document from a file on disk and obtain its interface. LoadXMLDocument creates a new TXMLDocument object and uses it to parse the file specified by the FileName parameter. The TXMLDocument component is not given an owner, which means that it behaves like an interfaced object. When the application releases the interface that LoadXMLDocument returns, the TXMLDocument instance is automatically freed.

 
 Xml.Win.msxmldom, Xml.XMLDoc,Xml.xmldom,Xml.XMLIntf,Winapi.msxml,

selectSingleNode

procedure TForm4.Parxml( Sender : TObject );

  var
noderef : IXMLDOMNodeRef;
root : IXMLDOMNode;
Node : IXMLDOMNode;
doc : IXMLDocument; begin
doc := LoadXMLDocument( 'test.xml' );
noderef := doc.DocumentElement.DOMNode as IXMLDOMNodeRef;
root := noderef.GetXMLDOMNode; // 获取跟节点
Node := root.selectSingleNode( 'ItemList/Item[@name="name2"]' );
// 根据路径的属性值获取节点 ShowMessage( Node.Attributes.getnameditem( 'title' ).Text ); // title2 Node.Attributes.getnameditem( 'title' ).Text := 'hello';
// <Item name="name2" title="title2"/> => <Item name="name2" title="hello"/> end;
  test.xml文档 :

  < ? Xml version = " 1.0 " encoding = " utf - 8 " ? > < test >< ItemList > <
Item name = " name1 " title = " title1 " > < / Item > <
Item name = " name2 " title = " title2 " / > < / ItemList > < / test >

<?xml version ="1.0" encoding ="utf-8"?>
<Project>
    <ItemList>
        <Item name ="name1" title ="title1"/>
        <Item name ="name2" title ="title2"/>
    </ItemList>
</Project>

ptNodes: IXMLDOMNode;

pas:=  ptnodes.text;//读取节点值要用text,nodeValue取不到
        pName := ptNodes.nodeName;
        pas := ptNodes.nodeValue;//error null

解析C++builder工程文件

原始工程文件首行是<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">

改成<Project>才能用selectSingleNode方法解析。

procedure TForm2.Button1Click(Sender: TObject);
var
path: string;
Xml: IXMLDocument;
noderef: IXMLDOMNodeRef;
Root: IXMLDOMNode;
Node: IXMLDOMNode;
ConditionStr: string;
list: TStringList;
begin
list := TStringList.Create;
list.LoadFromFile('E:\test\tt.cbproj');
list.Strings[] := '<Project>';
Xml := LoadXMLData(list.Text);
noderef := Xml.DocumentElement.DOMNode as IXMLDOMNodeRef;
Root := noderef.GetXMLDOMNode;
path := 'PropertyGroup[@Condition="''$(Cfg_1_Win32)''!=''''"]/FinalOutputDir';
Node := Root.selectSingleNode(path);
if not Assigned(Node) then
self.Caption := 'not not '
else
Caption := Node.nodeTypedValue;
list.Free;
end;

C++builder

Winapi.msxmlIntf.hpp

Xml.Win.msxmldom.hpp

http://docwiki.embarcadero.com/Libraries/Berlin/en/Xml.Win.msxmldom.IXMLDOMNodeRef.GetXMLDOMNode

_di_IXMLDOMDocument xdocm;

_di_IXMLDOMNodeRef xdnodeRef;
    _di_IXMLDOMNode xdnode,xdnode2;

noderef := xml.DocumentElement.domnode as IXMLDOMNodeRef;
  root := noderef.GetXMLDOMNode;

//c++读取属性节点

xdnodeRef = XMLDocument1->DocumentElement->DOMNode;

xdnode = xdnodeRef->GetXMLDOMNode();

xdnode->selectSingleNode(L"MakeItems/Item[@Name='teacher']", &xdnode2);

BSTR name;
    xdnode2->get_nodeName(&name);

this->Caption = name;

xdnode->selectSingleNode

IXMLDOMDocument

_di_IDOMNode dnode;

_di_IXMLDOMNodeList domNodeList;

xdnode = dnode->firstChild;
//     dnode->hasChildNodes();

void Test_DOMVendor() {
TXMLDocument *document;
TDOMVendor *vendor; document = new TXMLDocument(NULL); // Get document vendor.
vendor = document->DOMVendor;
if (vendor != ) {
printf("Document DOM vendor is \"%ls\".\n", vendor->Description());
}
else {
printf("Document has no DOM vendor.\n");
} // Display registered DOM vendors with this application.
const int numVendors = DOMVendors->Count();
printf("Number of registered DOM vendors with this application is %d.\n",
numVendors);
for (int i = ; i < numVendors; i++) {
vendor = DOMVendors->Vendors[i];
printf("\t%ls\n", vendor->Description());
} // Find a specific registered DOM vendor.
vendor = DOMVendors->Find("MSXML");
if (vendor != ) {
// Set document DOM vendor.
document->DOMVendor = vendor;
printf("Document DOM vendor is \"%ls\".\n",
document->DOMVendor->Description());
}
else {
printf("Could not find DOM vendor.\n");
} delete document;
}

 遍历节点

XmlNode: IXMLNode;
  XmlNodeList: IXMLNodeList

XmlNodeList := Xml.DocumentElement.ChildNodes;

XmlNode := XmlNodeList.First;
  while XmlNode <> nil do
  begin
    self.list_values.AddPair(XmlNode.NodeName, XmlNode.NodeValue);
    XmlNode := XmlNode.NextSibling;
  end;

保存文件

procedure TFrmPublicHealthMain.PNGButton1Click(Sender: TObject);
var
pNode,cNode: IXMLNode; {定义两个节点: 父节点、子节点}
astr:string;
ms:TMemoryStream ;
ss:TStringStream;
begin
XMLDocument1.XML.Clear;
XMLDocument1.Active := True; {必须先激活}
XMLDocument1.Version := '1.0'; {设置版本}
XMLDocument1.Encoding := 'utf-8'; {设置语言} pNode := XMLDocument1.AddChild('科室名单'); {添加的第一个节点是根节点, 现在的 pNode 是根节点}
pNode.SetAttribute('备注', '测试'); {为根节点设置属性} pNode := pNode.AddChild('人员'); {为根节点添加子节点, 现在的 pNode 是 "人员" 节点}
pNode.SetAttribute('职务', '科长'); {设置属性}
pNode.SetAttribute('备注', '正局级'); cNode := pNode.AddChild('姓名'); {为 pNode 添加子节点, 返回值 cNode 指向了新添加的节点}
cNode.Text := '张三'; cNode := pNode.AddChild('性别');
cNode.Text := '男'; cNode := pNode.AddChild('年龄');
cNode.Text := ''; {查看} //缺少 Encoding
ShowMessage(XMLDocument1.XML.Text); {保存}
XMLDocument1.SaveToFile('2.xml');
XMLDocument1.SaveToXML(astr);
self.mmoIn.Lines.Text := astr; //这样就有encoding了
ms:= TMemoryStream.Create;
XMLDocument1.SaveToStream(ms);
ss := TStringStream.Create;
ms.Position:=;
ss.CopyFrom(ms,ms.Size);
self.mmoIn.Lines.Text := ss.DataString;
ss.Free;
ms.Free; end;

pNode.ChildValues['cfh'] := '023535325';

C#  XmlTextWriter

https://www.cnblogs.com/gc2013/p/4267636.html

// XmlTextWriter 写文件
XmlTextWriter writeXml = new XmlTextWriter(@c:MyXml.xml,Encoding.UTF8);
writeXml.WriteStartDocument(false);
writeXml.WriteStartElement(NetWork); writeXml.WriteComment(网络配置信息);
writeXml.WriteStartElement(configration); writeXml.WriteElementString(IpAddress,192.168.2.168);
writeXml.WriteElementString(Netmask, 255.255.255.0);
writeXml.WriteElementString(Gateway, 202.103.24.68); writeXml.WriteEndElement();
writeXml.WriteEndElement(); writeXml.Flush();
writeXml.Close();

不用findNode的写法

Xml.DocumentElement.ChildNodes['makeCard'].ChildNodes['sfzCard'].NodeValue

遍历节点

  self.XMLDocument1.LoadFromXML(Memo2.Lines.Text);
for i := to XMLDocument1.DocumentElement.ChildNodes.Count - do
begin
self.Caption := XMLDocument1.DocumentElement.ChildNodes[i].NodeName;
self.Caption := XMLDocument1.DocumentElement.ChildNodes[i].Text;
end;
    for (int i = ; i < XMLDocument1->DocumentElement->ChildNodes->Count; i++)
{ s1 = XMLDocument1->DocumentElement->ChildNodes->Get(i)->NodeName;
s2= XMLDocument1->DocumentElement->ChildNodes->Get(i)->Text;
}

ShowMessage(Node.Attributes.getnameditem('title').Text); // title2   Node.Attributes.getnameditem('title').Text:='hello'; // <Item name="name2" title="title2"/>  =>  <Item name="name2" title="hello"/>
  XMLDocument1.SaveToFile('test.xml');

C# 保存时:
 dtXML.WriteXmlSchema("d://sampleSchema.xml");
 dtXML.WriteXml("d://sample.xml");
读取时:
 dtXML.ReadXmlSchema("d://sampleSchema.xml");
 dtXML.ReadXml("d://sample.xml");

DataSet dataSet = new DataSet();

DataTable dataTable = new DataTable();

dataSet.Tables.Add(dataTable);

dataSet.WriteXml("123.xml");

dataSet.ReadXml("123.xml");

DataTable dataTable = dataSet.Tables[0];

DataTable dt = new DataTable();
            dt.ReadXmlSchema("aschema.xml");
            dt.ReadXml("testout.txt");

DataView dv = dt.DefaultView;
            dv.RowFilter = "BKA265='未对应'";

//1.过滤后直接获取DataTable
            DataTable newTable1 = dv.ToTable();

this.dataGridView1.DataSource = newTable1;

有了这个Schema,解析xml太牛了

xml数据文件,就直接到数据集了databable

<?xml version="1.0" encoding="utf-8" standalone="no"?>
<data1>
<row>
<AKB020>0010023</AKB020>
<AKC190>000000053628455</AKC190>
<BKC037>1</BKC037>
<AKC220>0</AKC220>
<AAE073>0001218982</AAE073>
<AAE072>00002</AAE072>
</row>
<row>
<AKB020>0010023</AKB020>
<AKC190>000000053628455</AKC190>
<BKC037>1</BKC037>
<AKC220>0</AKC220>
<AAE073>0001218982</AAE073>
<AAE072>00002</AAE072>
</row>
XMLSchema
<?xml version="1.0" standalone="yes"?>
<xs:schema id="NewDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xs:element name="NewDataSet" msdata:IsDataSet="true" msdata:MainDataTable="row" msdata:UseCurrentLocale="true">
<xs:complexType>
<xs:choice minOccurs="0" maxOccurs="unbounded">
<xs:element name="row">
<xs:complexType>
<xs:sequence>
<xs:element name="AKB020" type="xs:string" minOccurs="0" />
<xs:element name="AKC190" type="xs:string" minOccurs="0" />
<xs:element name="BKC037" type="xs:string" minOccurs="0" />
<xs:element name="AKC220" type="xs:string" minOccurs="0" />
<xs:element name="AAE073" type="xs:string" minOccurs="0" />
<xs:element name="AAE072" type="xs:string" minOccurs="0" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>

TNativeXml *DocXml = new TNativeXml(NULL);

DocXml->Root->NodeByName("sqldata")->NodeByName("Row")->NodeByName("prm_sysdate")->ValueUnicode;

c#写xml

 XmlTextWriter myXmlTextWriter = new XmlTextWriter(System.IO.Directory.GetCurrentDirectory()+@"\KPDZJKK.xml", null);
//使用 Formatting 属性指定希望将 XML 设定为何种格式。 这样,子元素就可以通过使用 Indentation 和 IndentChar 属性来缩进。
myXmlTextWriter.Formatting = Formatting.Indented;
myXmlTextWriter.WriteStartDocument(false);
myXmlTextWriter.WriteStartElement("bookstore");
myXmlTextWriter.WriteStartElement("book");
myXmlTextWriter.WriteAttributeString("paname", paname);
myXmlTextWriter.WriteAttributeString("sfzh", sfzh);
myXmlTextWriter.WriteAttributeString("phone", phone);
myXmlTextWriter.WriteAttributeString("sex", sex);
myXmlTextWriter.WriteAttributeString("mz", mz);
myXmlTextWriter.WriteAttributeString("VUId", VUId);
myXmlTextWriter.WriteEndElement();
myXmlTextWriter.Flush();
myXmlTextWriter.Close();

c#读取xml

            string ykt_in_xml;
ykt_in_xml = System.IO.Directory.GetCurrentDirectory() + @"\KPDZJKK_YKT.xml";
XmlDocument doc = new XmlDocument();
if (System.IO.File.Exists(ykt_in_xml))
{
doc.Load(ykt_in_xml);
nametxtbox.Text = doc.SelectSingleNode("/bookstore/book").Attributes["paname"].Value;
sextxtbox.Text = doc.SelectSingleNode("/bookstore/book").Attributes["sex"].Value;
mztxtbox.Text = doc.SelectSingleNode("/bookstore/book").Attributes["mz"].Value;
phonetxtbox.Text = doc.SelectSingleNode("/bookstore/book").Attributes["phone"].Value;
codetxtbox.Text = doc.SelectSingleNode("/bookstore/book").Attributes["sfzh"].Value;

对象转换为XML,类转换为XML

智能是class,因为record不支持这种rtti的反射。record用json的序列化是支持的,没时间研究官方的序列化怎么做到支持record的;

TRttiField是字段,public里定义的就是字段能获取到。
TRttiProperty是属性,要在published里定义才能获取到。
不过这已经很方便了,对象转xml。
 function obj2xml(rootName:string;obj:TObject):string;
var
xmldcoc: IXMLDocument;
pNode: IXMLNode;
t: TRttiType;
// p: TRttiProperty;
f: TRttiField;
r: TValue;
begin
t := TRttiContext.Create.GetType(obj.ClassType );
xmldcoc := NewXMLDocument('');
pNode := xmldcoc.AddChild(rootName);
for f in t.GetFields do
pNode.AddChild(f.name).Text := f.GetValue(obj).ToString;
result := xmldcoc.Xml.Text;
end;

<request>
    <name>张飞</name>
    <age>28</age>
    <sex>男</sex>
</request>

调用代码

procedure TForm1.Button15Click(Sender: TObject);
var
obj:tperson;
begin
obj := tperson.Create();
obj.name := '张飞';
obj.age := ;
obj.sex := '男';
self.Memo1.Text:= obj2xml('request',obj);
obj.Free;
end;

tperson = class
  public
    name: string;
    age: Integer;
    sex: string;
  end;

XML2ds

<?xml   version="1.0"   encoding="gb2312"?>
<!--文档版本信息, 注释格式同HTML-->
<data>
<row>
<id>11</id>
<name>AAA</name>
<sex>男9</sex>
<age>24</age>
</row>
<row>
<id>12</id>
<name>BBB</name>
<sex>女8</sex>
<age>25</age>
</row>
<row>
<id>13</id>
<name>CCC</name>
<sex>女7</sex>
<age>26</age>
</row>
<row>
<id>4</id>
<name>DDD</name>
<sex>男6</sex>
<age>28</age>
</row>
</data>
function XMLToDataSet(strXML: WideString): TClientDataSet;
var
myDataSet: TClientDataSet;
s: string;
xdoc: IXMLDOMDocument;
xdn: IXMLDOMNode;
xdns: IXMLDOMNodeList;
i, j: Integer;
begin // 上面的格式就是传递参数strXML:WideString的格式,必须用row节点
strXML := s;
Form23.Memo1.Text := strXML;
myDataSet := TClientDataSet.Create(nil);
xdoc := CreateDOMDocument();
xdoc.loadXML(strXML);
// xdoc.load('c:\test.xml');
s := '';
xdn := xdoc.documentElement;
xdns := xdoc.selectNodes('//row');
try
begin
for i := to xdns.item[].childNodes.length - do
begin
myDataSet.FieldDefs.Add(xdns.item[].childNodes[i].nodeName, ftstring, );
end;
myDataSet.CreateDataSet; // 建立
myDataSet.Active; for i := to xdns.length - do
begin
myDataSet.Append;
for j := to xdns.item[i].childNodes.length - do
begin
myDataSet.FieldValues[xdns.item[i].childNodes[j].nodeName] := xdns.item[i].childNodes[j].text;
end;
myDataSet.Post;
end; end;
except
on Ex: Exception do
// ShowMessage(Ex.Message);
myDataSet := nil;
end; result := myDataSet; end;

c++Builder Delphi XML 解析例子的更多相关文章

  1. Delphi之通过代码示例学习XML解析、StringReplace的用法(异常控制 good)

    *Delphi之通过代码示例学习XML解析.StringReplace的用法 这个程序可以用于解析任何合法的XML字符串. 首先是看一下程序的运行效果: 以解析这样一个XML的字符串为例: <? ...

  2. Delphi中解析Xml的控件-SimDesign NativeXml

    Delphi中解析Xml的控件-SimDesign NativeXml 正在学习,感觉应用很方便.无源代码的版本还是免费的. SimDesign.NativeXml是一个delphi和bcb的XML控 ...

  3. DOM解析XML文件例子

    DOM解析XML文件是一次性将目标文件中的所有节点都读入,然后再进行后续操作的方式. 一般分为以下几步: 1. 定义好目标XML文件路径path . 2. 实例化DOM解析工厂对象 ,Document ...

  4. Android实现XML解析技术

    转载:Android实现XML解析技术 本文介绍在Android平台中实现对XML的三种解析方式. XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为 ...

  5. Java XML解析器

    使用Apache Xerces解析XML文档 一.技术概述 在用Java解析XML时候,一般都使用现成XML解析器来完成,自己编码解析是一件很棘手的问题,对程序员要求很高,一般也没有专业厂商或者开源组 ...

  6. Java的XML解析

    XML:(eXtensible Markup Language) 可扩展标记语言 是一种数据格式,用于存储和传输数据 声明一个xml文件 <?xml version="1.0" ...

  7. XML解析——DOM解析

    XML:可扩展性标记语言,主要用来传输和存储数据,相对于HTML的各种标签规范,XML的标签可以让用户根据语义自己进行定义,适用于web传输. JSON和XML的区别: (1).XML定义 扩展标记语 ...

  8. 【Android】实现XML解析的几种技术

    本文介绍在Android平台中实现对XML的三种解析方式. XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能. 在 ...

  9. tinyxml一个优秀的C++ XML解析器

    读取和设置xml配置文件是最常用的操作,试用了几个C++的XML解析器,个人感觉TinyXML是使用起来最舒服的,因为它的API接口和Java的十分类似,面向对象性很好. TinyXML是一个开源的解 ...

随机推荐

  1. 每天一个linux命令:【转载】head命令

    head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾. 1.命令格式: hea ...

  2. JLOI2019游记

    JLOI2019游记 DAY -??? 听说是12省联考,好刺激. DAY 1 看题 t1是个lydsy题我还写过博客,t2不会,t3一脸神仙. 这个t3数据好大啊,看到好几个人都用gedit打开大样 ...

  3. wamp配置局域网访问

    Apache的版本是2.4.9. <Directory "D:/wamp/www/">    #    # Possible values for the Option ...

  4. hdu4261 Estimation[暴力dp+对顶堆]

    https://vjudge.net/problem/HDU-4261 对于一个长2000的数列划分最多25个块,每块代价为块内每个数与块内中位数差的绝对值之和,求最小总代价. 套路化地,设$f[i] ...

  5. 安装Zookeeper(集群版)

    一.环境介绍(3台虚拟机) IP Hostname 192.168.2.14 javaweb04 192.168.2.15 javaweb05 192.168.2.16 javaweb06 二.配置文 ...

  6. error: device not found

    C:\Users\Administrator>adb shell error: device not found    出现上面情况,首先检查设备管理器中,安卓的驱动是否安装OK?   如果驱动 ...

  7. jeecg中一对多的关系映射

    1.首先看一张前端页面: 有一张主表和3张子表,显示这3张子表的代码如下 <t:tabs id="tt" iframe="false" tabPositi ...

  8. golang里面检测对象是否实现了接口的方法

    写法有点怪异,记一下吧 _, implemented := this.delegate.(IGenTcpServerDelegate) if implemented { this.delegate.G ...

  9. 洛谷八连测R4

    1.逃避 https://www.luogu.org/problemnew/show/T14561 注意: 1.输入时需要用EOF判断,否则会TLE. 2.用flag判断字符是不是每一句首字母. 3. ...

  10. 获取响应里面的cookie的方法

    使用方法: R.cookies.get_dict()   获取响应返回的cookies