C# 如何提取xml中所有文本节点的内容

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

c# 如何提取xml中所有文本节点的内容

在 C# 中提取 XML 文档中所有文本节点的内容,可以使用 System.Xml 命名空间中的类,如 XDocumentXmlDocument。推荐使用 XDocument(LINQ to XML),语法更简洁。

使用 XDocument 提取所有文本节点

以下方法会遍历整个 XML 文档,找到所有文本节点并提取其内容:

示例代码:

// 示例 XML 字符串
string xml = @”

张三
25

这是一条备注信息。
“;

var doc = XDocument.Parse(xml);

// 提取所有文本节点内容
var textNodes = doc.DescendantNodes()
.OfType()
.Select(t => t.Value.Trim())
.Where(value => !string.IsNullOrEmpty(value));

foreach (var text in textNodes)
{
Console.WriteLine(text);
}

输出结果:

张三
25
这是一条备注信息。

说明与注意事项

DescendantNodes() 获取所有子节点(包括元素、文本、注释等)
OfType() 筛选出仅文本节点
Value.Trim() 去除首尾空白,避免换行或缩进干扰
Where 过滤空字符串 排除纯空白的文本节点

处理包含 CDATA 的情况

如果 XML 包含 CDATA 节点,比如:

重要内容]]>

LINQ to XML 会将其作为 XText 节点处理,Value 直接返回 CDATA 内容(即 重要内容),无需特殊处理。

从文件加载 XML

若 XML 存在于文件中,使用:

var doc = XDocument.Load(“path/to/file.xml”);

基本上就这些。使用 LINQ to XML 可以简洁高效地提取所有文本内容,适合大多数场景。

以上就是C# 如何提取xml中所有文本节点的内容的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1440889.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 17:33:01
下一篇 2025年12月17日 17:33:12

相关推荐

发表回复

登录后才能评论
关注微信