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