簡體   English   中英

將XML節點解析為數組

[英]Parse XML nodes to an array

我想從下面的XML中的元素ROW獲取所有屬性的數組

 <?xml version="1.0" encoding="windows-1251"?> <DATAPACKET Version="2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.seavus.com/AML/XML-Schema/CTR_Single.xsd"> <banka> <!-- banka children --> </banka> <METADATA> <FIELDS> <!-- Fields --> </FIELDS> <PARAMS LCID="0" /> </METADATA> <ROWDATA> <ROW BANK_ID="370" AKTIVNOST_SE_VRSI_VO_19="Г" NAZIV_21="XXXXX" SEDISTE_21="XX" DANOCEN_BROJ_21="12333" BROJ_SMETKA_21="123333" BANKA_21="330" DATUM_22="03.01.2017" CAS_22="13:30" VID_AKTIV_23="XXX" IZNOS_24="12" VALUTA_24="807" DATUM_25="04.01.2017" VREME_25="12:55" SIFRA_26="800" OPIS_27="XXXXXXX" /> </ROWDATA> </DATAPACKET> 

為了清楚起見,我想從該節點創建一個數組:

 <ROW BANK_ID="370" AKTIVNOST_SE_VRSI_VO_19="Г" NAZIV_21="XXXXX" SEDISTE_21="XX" DANOCEN_BROJ_21="12333" BROJ_SMETKA_21="123333" BANKA_21="330" DATUM_22="03.01.2017" CAS_22="13:30" VID_AKTIV_23="XXX" IZNOS_24="12" VALUTA_24="807" DATUM_25="04.01.2017" VREME_25="12:55" SIFRA_26="800" OPIS_27="XXXXXXX" /> 

我想使用此數組來生成插入查詢。

到目前為止我嘗試過的是:

doc.Load(path);
ArrayList list = new ArrayList();
XmlNode idNodes = doc.SelectSingleNode("DATAPACKET/ROWDATA/ROW");
foreach (XmlNode node1 in idNodes.Attributes)
{
    list.Add(node1.InnerText);
}

我有從XML在線生成的類,並且正在使用它們反序列化XML文件。

您可以為名稱/值對創建字典。 使用Linq2Xml:

(不要忘記默認的XmlNamespace)

var xDoc = XDocument.Parse(xmlstring);
XmlNamespaceManager mgr = new XmlNamespaceManager(xDoc.CreateNavigator().NameTable);
mgr.AddNamespace("ns", "http://www.seavus.com/AML/XML-Schema/CTR_Single.xsd");

var dict = xDoc.XPathSelectElement("//ns:ROWDATA/ns:ROW",mgr)
                .Attributes()
                .ToDictionary(a => a.Name, a => a.Value);

返回的字典將是:

BANK_ID: 370
AKTIVNOST_SE_VRSI_VO_19: Г
NAZIV_21: XXXXX
SEDISTE_21: XX
DANOCEN_BROJ_21: 12333
BROJ_SMETKA_21: 123333
BANKA_21: 330
DATUM_22: 03.01.2017
CAS_22: 13:30
VID_AKTIV_23: XXX
IZNOS_24: 12
VALUTA_24: 807
DATUM_25: 04.01.2017
VREME_25: 12:55
SIFRA_26: 800
OPIS_27: XXXXXXX

您的主要問題是從錯誤的名稱空間中選擇的。 同樣,當然,沒有可供選擇的數據行。

這似乎可行:

doc.Load(yourPath);
var list = new ArrayList();
XmlNamespaceManager mgr = new XmlNamespaceManager(doc.CreateNavigator().NameTable);
mgr.AddNamespace("ns", "http://www.seavus.com/AML/XML-Schema/CTR_Single.xsd");
var idNodes = doc.DocumentElement?.SelectSingleNode("ns:ROWDATA/ns:ROW", mgr);
foreach (XmlNode attr in idNodes.Attributes)
    list.Add(attr.Name);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM