是否有用于搜索和修改树结构的正则表达式等价物?我正在寻找简洁的迷你语言(如 perl 正则表达式)。
这是一个示例,可以阐明我在寻找什么。
<root>
<node name="1">
subtrees ....
</node>
<node name="2">
<node name="2.1">
data
</node>
other subtrees...
</node>
</root>
在上述树上可能的操作是“将节点 2.1 的子树移动到节点 1 的子树中”。操作的结果可能看起来像..
<root>
<node name="1">
subtrees ....
<node name="2.1">
data
</node>
</node>
<node name="2">
other subtrees...
</node>
</root>
搜索和替换操作,例如查找所有具有至少 2 个子节点的节点、查找数据以“a”开头的所有节点,如果子树至少有 2 个其他兄弟节点,则将其替换为“b”等。应该支持。
对于字符串,其中唯一的维度是字符串的长度,我们可以使用正则表达式执行许多上述操作(或它们的一维等效项)。我想知道是否有树的等价物。(而不是单个正则表达式,您可能需要编写一组转换规则,但这没关系)。
我想知道是否有一些简单的迷你语言(不是正则表达式本身,而是通过库等可以像正则表达式一样访问的东西)。执行这些操作?最好作为 python 库。