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

在 C# 中提取 XML 文档中所有文本节点的内容,可以使用 System.Xml 命名空间中的类,如 XDocument 或 XmlDocument。推荐使用 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
微信扫一扫
支付宝扫一扫