-6

我想更新 xml 节点数据,我有以下 xml 节点

<categories>
  <category>
    <id>1</id>
    <name>Computer</name>
    <description>Information tech.</description>
    <active>False</active>
  </category>
  <category>
    <id>2</id>
    <name>Cate1</name>
    <description>MMukh</description>
    <active>True</active>
  </category>
</categories>

例如类别 id=1,并将其数据提取到文本框。如何保存对此节点的更改。

非常感谢。

4

1 回答 1

-1

试试我的解决方案

string xml = @"<categories>
                <category>
                <id>1</id>
                <name>Computer</name>
                <description>Information tech.</description>
                <active>False</active>
                </category>
                <category>
                <id>2</id>
                <name>Cate1</name>
                <description>MMukh</description>
                <active>True</active>
                </category>
            </categories>";

XDocument xDoc = XDocument.Parse(xml);
int id = 1;

var items = xDoc.XPathSelectElement("//category[id=" + id + "]")
            .Elements()
            .ToDictionary(e => e.Name.LocalName, e => (string)e);

if (items != null)
{
    // display these fields to the text box
    Console.WriteLine(items["name"]);
    Console.WriteLine(items["description"]);
    Console.WriteLine(items["active"]);
}

您可以使用上面的代码在文本框中显示数据。和下面的代码用更新的数据更新现有的 xml。

// updated value for xml element - description
string description = "Computer 123";

var items1 = from item in xDoc.Descendants("category")
                where item.Element("id").Value == id.ToString()
                select item;

foreach (XElement itemElement in items1)
{
    itemElement.SetElementValue("name", description);
}
xDoc.Save("data.xml");

您可以在xDoc.

于 2013-05-06T13:54:10.167 回答