3

我需要解析被注释掉的 XML 标签

<DataType Name="SecureCode" Size="4" Type="NVARCHAR">
    <!-- <Validation>
            <Regex JavaPattern="^[0-9]*$" JSPattern="^[0-9]*$"/>
    </Validation> -->
    <UIType Size="4" UITableSize="4"/>
</DataType>

但我发现的只是setIgnoringComments(boolean)

Document doc = docBuilder.parse(new File(PathChecker.getDataTypesFile()));
docFactory.setIgnoringComments(true); // ture or false, no difference

但它似乎并没有改变任何东西。还有其他方法可以解析此评论吗?我必须使用 DOM。

问候

4

2 回答 2

5

方法“setIgnoringComments”在解析期间从 DOM 树中删除了注释。使用“setIgnoringComments(false)”,您可以获得如下评论文本:

    NodeList nl = doc.getDocumentElement().getChildNodes();
    for (int i = 0; i < nl.getLength(); i++) {
        if (nl.item(i).getNodeType() == Element.COMMENT_NODE) {
            Comment comment=(Comment) nl.item(i);
            System.out.println(comment.getData());
        }
    }
于 2013-11-15T08:53:39.093 回答
0

由于似乎不存在解决问题的“常规方法”,我刚刚删除了评论。

BufferedReader br = new BufferedReader(new FileReader(new File(PathChecker.getDataTypesFile())));
BufferedWriter bw = new BufferedWriter(new FileWriter(new File(PathChecker.getDataTypesFileWithoutComments())));

String line = "";

while ((line = br.readLine()) != null) {
    line = line.replace("<!--", "").replace("-->", "") + "\n";
    bw.write(line);
}
于 2013-11-15T08:46:26.527 回答