使用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
属性值(key2和key3在这种情况下)以及Type
和Value
属性值的最简单方法是什么?
加载文档;
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
...
}