用 XmlDocument 或 XDocument 解析 XML 节点属性并存入 Dictionary 时,需先校验节点非空,再遍历 Attributes 集合;处理命名空间需用 XNamespace 前缀,缺失属性用 Attribute(name)?.Value ?? defaultValue 安全获取,重复键可改用 List 或自定义合并逻辑,封装为通用静态方法可提升复用性与健壮性。

用 XmlDocument 或 XDocument 解析 XML 节点,遍历其属性,逐个添加到 Dictionary 中即可。关键在于正确获取属性集合,并处理重复键、空值等边界情况。
使用 XmlDocument 读取节点属性到字典
XmlDocument 是传统且稳定的方式,适合 .NET Framework 和较老项目。先定位目标节点(如通过 SelectSingleNode),再遍历其 Attributes 集合:
- 确保节点不为
null,否则访问Attributes会抛出异常 -
XmlAttribute的Name和直接对应字典的键和值
- 若存在同名属性(XML 标准不允许,但解析器可能容忍),后出现的会覆盖前面的
var doc = new XmlDocument();
doc.Load("data.xml");
XmlNode node = doc.SelectSingleNode("//Person"); // 假设有一个
if (node != null && node.Attributes != null)
{
var dict = new Dictionary();
foreach (XmlAttribute attr in node.Attributes)
{
dict[attr.Name] = attr.Value;
}
// dict 现在包含 {["id"] = "101", ["name"] = "Alice"}
}
使用 XDocument(LINQ to XML)更简洁
XDocument 是现代推荐方式,语法更直观,支持 LINQ 查询。用 Element 或 Descendants 找到节点后,调用 Attributes() 方法获取所有 XAttribute:
-
XAttribute.Name.LocalName获取属性名(推荐,避免命名空间干扰) -
XAttribute.Value即属性值,自动处理转义和空白 - 可用
ToDictionary()一行构建字典,但需注意键重复时会抛异常
var xdoc = XDocument.Load("data.xml");
var person = xdoc.Root?.Element("Person"); // 或 xdoc.Descendants("Person").FirstOrDefault()
if (person != null)
{
var dict = person.Attributes()
.ToDictionary(a => a.Name.LocalName, a => a.Value);
}
处理常见问题:命名空间、默认值与重复键
真实 XML 常含命名空间或缺失属性,直接硬编码可能失败:
- 带命名空间时,用
XNamespace前缀匹配,例如ns + "Person" - 某些属性可能不存在,建议用
Attribute(string name)?.Value安全获取,配合空合并操作符提供默认值 - 若需允许重复键(如多个同名属性),改用
List或自定义逻辑合并值>
var id = person.Attribute("id")?.Value ?? "unknown";
var type = person.Attribute("type")?.Value ?? "default";
封装成通用方法便于复用
把逻辑抽成静态方法,支持任意 XmlNode 或 XElement,提升可维护性:
- 接受节点对象和可选的默认值映射(如把空属性映射为
"N/A") - 内部做非空检查,避免调用方重复判断
- 返回
ReadOnlyDictionary可防止外部意外修改
public static DictionaryGetAttributesAsDict(XElement element, string defaultValue = "") { if (element == null) return new Dictionary (); return element.Attributes() .ToDictionary(a => a.Name.LocalName, a => string.IsNullOrEmpty(a.Value) ? defaultValue : a.Value); }










