使用XDocument提取XML所有文本节点:解析XML后通过DescendantNodes().OfType<XText>()获取文本节点,Select(t=>t.Value.Trim())提取并去除空白,Where过滤空值,可处理CDATA,结果输出为“张三”“25”“这是一条备注信息。”。

在 C# 中提取 XML 文档中所有文本节点的内容,可以使用 System.Xml 命名空间中的类,如 XDocument 或 XmlDocument。推荐使用 XDocument(LINQ to XML),语法更简洁。
以下方法会遍历整个 XML 文档,找到所有文本节点并提取其内容:
示例代码:
// 示例 XML 字符串输出结果:
张三DescendantNodes() 获取所有子节点(包括元素、文本、注释等)
OfType<XText>() 筛选出仅文本节点
Value.Trim() 去除首尾空白,避免换行或缩进干扰
Where 过滤空字符串 排除纯空白的文本节点
如果 XML 包含 CDATA 节点,比如:
<description><![CDATA[<b>重要内容</b>]]></description>LINQ to XML 会将其作为 XText 节点处理,Value 直接返回 CDATA 内容(即 重要内容),无需特殊处理。
若 XML 存在于文件中,使用:
var doc = XDocument.Load("path/to/file.xml");基本上就这些。使用 LINQ to XML 可以简洁高效地提取所有文本内容,适合大多数场景。
以上就是C# 如何提取xml中所有文本节点的内容的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号