我需要在服务器上解析一个巨大的 xml 文件并将其发送给客户端。
我想按需进行解析 - 意思是,首先只解析和显示父节点,当客户端单击父节点时 - 向服务器发送一个请求,告诉服务器选择了哪个父节点,然后到解析并发送它的孩子(同样,不是整个子树,而只是父母)。
我考虑过使用 STAX 解析器,但在涉及父子关系时我不明白如何使用它。我如何告诉解析器不要继续到下一个 START-ELEMENT 子元素,而是跳到其级别的下一个父元素?还有 - 有没有办法回到 ITERATOR 实现?选择一个父母并看到它的孩子后,我可以回去看前一个父母吗?
我真的很感激任何建议!
谢谢你。
问问题
3451 次
1 回答
3
不,您不能在不先解析 XML 文档的情况下跳过它的子树。对于每个解析器都是如此,而不仅仅是 StAX。(知道要跳到哪一点意味着您已经解析了两者之间的元素。)
但是,通过维护一个随每个开始元素事件递增并随每个结束元素事件递减的嵌套级别计数器,很容易忽略来自低于目标级别的级别的所有事件。
解析是一种方式,不是随机访问,不能来回跳转。(同样,这将假定解析器存储到目前为止已解析的所有内容的表示,这正是创建 StAX 来避免的。)当然,您可以尝试记录文件中每个父标记的字节位置,然后稍后如果您已打开文件以进行随机访问,请寻求它。但是,这种方法有很多陷阱。
总而言之,您的用例看起来不太适合 StAX。您尝试过VTD-XML吗?根据您的文件有多大,它可能正是您想要的。
于 2012-10-28T11:35:53.983 回答