4

興味深いのですが、xml ノードの文字列を解析して XmlNodeList にする最も適切な方法は何でしょうか。例えば;

string xmlnodestr = "<mynode value1='1' value2='123'>abc</mynode>
<mynode value1='1' value2='123'>abc</mynode>
<mynode value1='1' value2='123'>abc</mynode>";

リストで文字列分割を行うこともできますが、それは面倒で適切ではありません。

理想的には、次のようなものが必要です。

XmlNodeList xmlnodelist = xmlnodestr.ParseToXmlNodeList();

4

2 に答える 2

3

XML にルートを追加してから、次のアプローチを使用できます。

string xmlnodestr = @"<mynode value1=""1"" value2=""123"">abc</mynode><mynode value1=""1"" value2=""123"">abc</mynode><mynode value1=""1"" value2=""123"">abc</mynode>";
string xmlWithRoot = "<root>" + xmlnodestr + "</root>";
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.LoadXml(xmlWithRoot);
XmlNodeList result = xmlDoc.SelectNodes("/root/*");

foreach (XmlNode node in result)
{
    Console.WriteLine(node.OuterXml);
}

LINQ to XML を使用できる場合、これははるかに簡単になりますが、次の操作を行うことはできませんXmlNodeList

var xml = XElement.Parse(xmlWithRoot);
foreach (var element in xml.Elements())
{
    Console.WriteLine(element);
}
于 2011-11-17T17:10:18.857 に答える
2

XmlDocumentFragment以下は、.NET 2.0 でテストされたを使用して実行するサンプル プログラムです。

using System;
using System.Xml;
using System.Xml.XPath;

public class XPathTest
{
    public static void Main() {

        XmlDocument doc = new XmlDocument();
        string xmlnodestr = @"<mynode value1='1' value2='123'>abc</mynode>
<mynode value1='1' value2='123'>abc</mynode>
<mynode value1='1' value2='123'>abc</mynode>";

        XmlDocumentFragment frag = doc.CreateDocumentFragment();
        frag.InnerXml = xmlnodestr;

        XmlNodeList nodes = frag.SelectNodes("*");

        foreach (XmlNode node in nodes)
        {
            Console.WriteLine(node.Name + " value1 = {0}; value2 = {1}",
                              node.Attributes["value1"].Value,
                              node.Attributes["value2"].Value);
        }
    }
}

次の出力が生成されます。

mynode value1 = 1; value2 = 123
mynode value1 = 1; value2 = 123
mynode value1 = 1; value2 = 123
于 2011-11-17T17:13:06.063 に答える