如何用Java Dom4j Element实现去除首尾空格的文本,并转换为?
- 内容介绍
- 文章标签
- 相关推荐
本文共计963个文字,预计阅读时间需要4分钟。
`getTextTrim()`本身存在问题,它只是处理`Element`直接子节点中的文本内容,而忽略了所有空白文本节点(例如换行、缩进等)。如果XML中文字被注释、`CDATA`包囊,或中间包含了其他元素,`getTextTrim()`将返回空字符串。
- XML 里写的是
<name><![CDATA[ 张三 ]]></name>→getTextTrim()拿不到,得用element.getText()或遍历element.content() - 结构是
<title><em>Java</em>入门</title>→getTextTrim()只看到<em>这个元素,不看它后面的“入门”,结果为空 - XML 文件用了 UTF-8 BOM 或编码声明不一致,DOM 解析时某些文本节点可能根本没加载进来
想安全取到“看起来像一行文本”的内容,该怎么做
当你要的其实是“用户视角下这个标签显示出来的纯文本”,getTextTrim() 往往不够。更稳的方式是手动合并所有文本节点并 trim:
String text = element.getStringValue().trim();
getStringValue() 是 Dom4j 提供的递归方法,它会把所有子孙文本节点拼起来(包括跨元素的),再由你统一 trim。比自己写递归遍历 content 更简洁,也避开了 CDATA 和混合内容的坑。
本文共计963个文字,预计阅读时间需要4分钟。
`getTextTrim()`本身存在问题,它只是处理`Element`直接子节点中的文本内容,而忽略了所有空白文本节点(例如换行、缩进等)。如果XML中文字被注释、`CDATA`包囊,或中间包含了其他元素,`getTextTrim()`将返回空字符串。
- XML 里写的是
<name><![CDATA[ 张三 ]]></name>→getTextTrim()拿不到,得用element.getText()或遍历element.content() - 结构是
<title><em>Java</em>入门</title>→getTextTrim()只看到<em>这个元素,不看它后面的“入门”,结果为空 - XML 文件用了 UTF-8 BOM 或编码声明不一致,DOM 解析时某些文本节点可能根本没加载进来
想安全取到“看起来像一行文本”的内容,该怎么做
当你要的其实是“用户视角下这个标签显示出来的纯文本”,getTextTrim() 往往不够。更稳的方式是手动合并所有文本节点并 trim:
String text = element.getStringValue().trim();
getStringValue() 是 Dom4j 提供的递归方法,它会把所有子孙文本节点拼起来(包括跨元素的),再由你统一 trim。比自己写递归遍历 content 更简洁,也避开了 CDATA 和混合内容的坑。

