使用LINQ to XML获取自定义属性值

本文关键字:自定义属性 获取 XML LINQ to 使用 | 更新日期: 2023-09-27 18:19:01

我正在写入一个XML文件,稍后我将从中检索数据。

我是这样写文件的

  XNamespace testNM = "urn:lst-emp:emp";
                XDocument xDoc;
                string path = "project_data.xml";
                if (!File.Exists(path))
                {
                    xDoc = new XDocument(
                               new XDeclaration("1.0", "UTF-16", null),
                               new XElement(testNM + "Test")
                               );
                }
                else
                {
                    xDoc = XDocument.Load(path);
                }
                var element = new XElement("key",
                        new XAttribute("name", key),
                        new XElement("Type", type),
                        new XElement("Value", value));
                xDoc.Element(testNM + "Test").Add(element);
                // Save to Disk
                xDoc.Save(path);

这就是我的XML文件写入数据后的样子。

<?xml version="1.0" encoding="utf-16"?>
<Test xmlns="urn:lst-emp:emp">
  <key name="key2" xmlns="">
    <Type>int</Type>
    <Value>12312</Value>
  </key>
  <key name="key3" xmlns="">
    <Type>String</Type>
    <Value>asdfasd</Value>
  </key>
</Test>

现在,获得name属性值(key2key3在这种情况下)以及TypeValue属性值的最简单方法是什么?

使用LINQ to XML获取自定义属性值

加载文档;

XDocument doc = XDocument.Load(@"doc.xml");

循环key节点读取所需的内容;

foreach (var keyNode in doc.Root.Elements("key"))
{
    var name = keyNode.Attribute("name");
    var type = (string)keyNode.Element("Type"); // or .value to throw if there is no node
    ...
}