1

我的情况是这样的,我有一个字符串格式的xml数据。

<?xml version="1.0" encoding="utf-16"?>
<Tree AllowNodeEditing="True" ShowLineImages="False" CheckBoxes="True" EnableAjaxSkinRendering="False" AutoPostBackOnCheck="True" AutoPostBack="True">
 <Node Text="IMG_1468.JPG" Value="../../CMS/Images/Fotogalerie/548/IMG_1468.JPG" Checked="True" Selected="True" tekst="Afbeelding IMG_1468.JPG" thumb="../../CMS/Images/Thumbs/548/IMG_1468.JPG" />

从上面的字符串中,我需要选择每个节点的“值”并将其存储在数据表中。我怎样才能实现这一点..

4

5 回答 5

3

我会使用XElement类。

XElement xmlTree = XElement.Parse("yourXMLString");

然后您可以使用 XElement 方法分析每个元素,例如:

foreach (XElement el in xmlTree.Elements())
   // Do what you want with el

你也可以查询它:

<Tree>
  <Node Text="IMG_1468.JPG" Value="../../CMS/Images/Fotogalerie/548/IMG_1468.JPG" />
</Tree>

string yourValue = xmlTree.Elements("Node")
                      .Where(x => (string) x.Attribute("Text") == "IMG_1468.JPG")
                      .Select(x => (string) x.Attribute("Value"))
                      .Single();
于 2012-04-26T10:57:23.543 回答
3

一种方法是将字符串转换为 xmldoc,而不是使用 LINQ 读取 xmldoc:

字符串到 XML:

    String rawXml =
              @"<root>
                    <person firstname="Riley" lastname="Scott" />
                    <person firstname="Thomas" lastname="Scott" />
                </root>";
        XmlDocument xmlDoc = new XmlDocument();
        xmlDoc.LoadXml(rawXml);



var lv1s = from lv1 in xdoc.Descendants("person")
           select new { 
               firstname = lv1.Attribute("firstname").Value,
                lastname = lv1.Attribute("lastname").Value
           };
于 2012-04-26T10:42:49.320 回答
2

使用Linq to XML

XDocument doc = XDocument.Parse(xml_string);
var values = (from f in doc.Elements().Descendants()
              select f.Attribute("Value").Value).ToArray();
于 2012-04-26T10:54:06.497 回答
1
XmlNodeList elementList = doc.GetElementsByTagName("*");
for (int i = 0; i < elementList.Count; i++)
{
    string attrVal = elementList[i].Attributes["Value"].Value;
}
于 2012-04-26T10:56:56.287 回答
1
XDocument doc = XDocument.Parse(xml);
var values = from element in doc.XPathSelectElements("/Tree/Node")
                     where element.Attribute("Value") != null
                     select (element.Attribute("Value").Value);
于 2012-04-26T11:01:58.790 回答