在我已经作为字符串存储的复杂XML中,我必须进行一些文本/xml处理。目标是找到给定节点的某些节点的起始指数。除了节点( node /Element类引用)之外,我还有关于嵌套的信息:整数数组,表示应该进入哪个子节点。例如数组:
2 1 0和给定的树
root
|--root-child0
|--root-child1
|--root-child2
|--root-child2-child0
|--root-child2-child1
|--root-child2-child1-child0我在搜索root-child2-child1-child0
是否有可能找到这样的物品。仅仅查找字符串(String.indexOf())是不够的--在我的XML文件中有许多相同的标记。除了这个搜索之外,还有一个额外的困难--一些父标记和子标记之间可以存在一个额外的(Collection)标记。(例如,根- child 2的独生子可以是Collection,根-child 2-child 0和根-child 2-child 1是此集合的子)
-编辑
如果这可以帮助-我也可以,除了提到嵌套信息,有相应的节点名称的路径上的节点,我正在搜索。
-编辑2
使用这样的xml文件
<catalog>
<book id="bk101">
<author>Gambardella, Matthew</author>
<title>XML Developer's Guide</title>
<genre>Computer</genre>
</book>
<book id="bk102">
<author>Ralls, Kim</author>
<title>Midnight Rain</title>
<genre>Fantasy</genre>
<price>5.95</price>
</book>
</catalog>让我们假设,我有Node对象引用值为5.95的价格标签。此外,我还有关于筑巢的信息:
1 3说它是目录中的第二本书(0中的数字),在这本书中是第四标记(id="bk102")。
我想要的是
xmlRawBody.indexOf("<price>5.95</price>"). 为什么我不能用这个简单的方法?因为有可能相同的标签会出现在其他地方。我必须使用上面提到的,额外的嵌套信息。
发布于 2011-08-19 06:59:37
我所理解的是,你有类似2 1 0的信息。由此,您将创建一个节点root-child2-child1-chile0的名称。
要获得这样的指定节点,如果结构是固定的,那么您可以使用它创建xpath。
例如,如果您有值2 1 0,那么就构建类似于root/root-child2/root-child2-child1/root-child2-child1-child0的xpath。您可以使用这个xpath获取特定的节点元素。
您可以创建一个java函数,它相应地按照给定的值数组准备xpath。如果您有更多这样的元素,您需要找到一种方法来用xpath来标识它们。因为xpath很容易使用SAXParser获取这些值(如果您不想读取整个xml,只读取部分,那么使用SAXParser)。
希望这能有所帮助。
发布于 2011-08-19 09:36:19
将数组转换为XPath,并使用您选择的XPath引擎。例如,2 1 0将变成:/*[3]/*[2]/*[1]。请注意,XPath的位置是基于1的,所以您必须在每个索引中添加一个.
此外,XPath引擎将返回一个DOM节点,您可以对其执行任何您想要的操作。获取此节点的字符或字节偏移量并不是DOM和XPath规范的一部分,因此它依赖于实现。在大多数实现中,您不能这样做,因为在大多数应用程序中,您不关心。
https://stackoverflow.com/questions/7117931
复制相似问题