java cdata xml_java – 通过DOM解析器从XML处理CDATA

我以前从未处理过XML,所以我不确定如何在XML文件中处理CDATA.我迷失在节点,父节点,子节点,nList等中.

谁能告诉我这些代码片段的问题是什么?

我的getTagValue()方法适用于除“详细信息”之外的所有标记,“详细信息”是包含CDATA的标记.

.....

NodeList nList = doc.getElementsByTagName("Assignment");

for (int temp = 0; temp < nList.getLength(); temp ) {

Node nNode = nList.item(temp);

if (nNode.getNodeType() == Node.ELEMENT_NODE) {

Element eElement = (Element) nNode;

results = ("Class : " getTagValue("ClassName", eElement))

("Period : " getTagValue("Period", eElement))

("Assignment : " getTagValue("Details", eElement));

myAssignments.add(results);

}

}

.....

private String getTagValue(String sTag, Element eElement) {

NodeList nlList = eElement.getElementsByTagName(sTag).item(0).getChildNodes();

Node nValue = (Node) nlList.item(0);

if((CharacterData)nValue instanceof CharacterData)

{

return ((CharacterData) nValue).getData();

}

return nValue.getNodeValue();

}

解决方法:

我怀疑你的问题出在getTagValue方法的以下代码行中:

Node nValue = (Node) nlList.item(0);

你总是得到第一个孩子!但是你可能不止一个.

以下示例有3个子节点:文本节点“detail”,CDATA节点“with cdata”和文本节点“here”:

detail here

如果你运行你的代码,你只得到“细节”,你就会失去其余部分.

以下示例有1个子节点:CDATA节点“此处带有cdata的详细信息”:

如果你运行你的代码,你会得到一切.

但是上面这样写的例子如下:

现在有3个孩子因为空格和换行被选为文本节点.如果您运行代码,则会获得带有换行符的第一个空文本节点,其余部分将丢失.

您要么遍历所有子项(无论多少)并连接每个子项的值以获得完整结果,或者如果区分纯文本和CDATA内的文本并不重要,则在上面设置合并属性文档制作工厂首先:

DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();

docFactory.setCoalescing(true);

...

https://www.icode9.com/content-1-434451.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要从一个Java中的XML文件中获取CDATA标记中包含的文本内容,可以使用JavaXML解析器。以下是一个示例代码,演示如何使用JavaDOM解析器来获取CDATA标记中的文本内容: ```java import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import java.io.File; public class CDATAParser { public static void main(String[] args) { try { // 创建一个DocumentBuilderFactory对象 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 使用工厂对象创建DocumentBuilder对象 DocumentBuilder builder = factory.newDocumentBuilder(); // 使用DocumentBuilder对象解析XML文件,获取Document对象 Document document = builder.parse(new File("your_xml_file.xml")); // 获取XML文件的根元素 Element rootElement = document.getDocumentElement(); // 获取根元素下的所有子节点 NodeList nodeList = rootElement.getChildNodes(); // 遍历子节点 for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); // 判断节点是否为元素节点 if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 判断元素节点是否包含CDATA内容 if (element.getTagName().equals("your_cdata_tag")) { // 获取CDATA内容 String cdataValue = element.getTextContent(); System.out.println("CDATA内容: " + cdataValue); } } } } catch (Exception e) { e.printStackTrace(); } } } ``` 请将代码中的 `"your_xml_file.xml"` 替换为你要解析的XML文件的路径,`"your_cdata_tag"` 替换为CDATA标记的名称。运行代码后,你将得到CDATA标记中包含的文本内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值