lxml(或lxml.html):打印树结构

时间:2012-10-26 19:20:38

标签: python html xml lxml

我想以可区分的方式打印出etree的树结构(由html文档构成)(意味着两个etree应该以不同的方式打印出来)。

我的意思是结构是树的“形状”,它基本上是指所有标签,但没有属性,也没有文字内容。

有什么想法吗?在lxml中有什么东西可以做到这一点吗?

如果没有,我想我必须遍历整个树并从中构造一个字符串。知道如何以紧凑的方式表示树吗? (“紧凑”功能不太相关)

仅供参考,不打算查看,而是存储和散列,以便能够在几个html模板之间产生差异。

由于

1 个答案:

答案 0 :(得分:9)

也许只是在源XML上运行一些XSLT去除除标签之外的所有内容,然后使用etree.tostring来获取可以散列的字符串就足够了......

from lxml import etree as ET

def pp(e):
    print ET.tostring(e, pretty_print=True)
    print

root = ET.XML("""\
<project id="8dce5d94-4273-47ef-8d1b-0c7882f91caa" kpf_version="4">
<livefolder id="8744bc67-1b9e-443d-ba9f-96e1d0007ba8" idref="707cd68a-33b5-4051-9e40-8ba686c2fdb8">Mooo</livefolder>
<livefolder id="8744bc67-1b9e-443d-ba9f" idref="707cd68a-33b5-4051-9e40-8ba686c2fdb8" />
<preference-set idref="8dce5d94-4273-47ef-8d1b-0c7882f91caa">
  <boolean id="import_live">0</boolean>
</preference-set>
</project>
""")
pp(root)


xslt = ET.XML("""\
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:template match="*">
    <xsl:copy>
      <xsl:apply-templates select="*"/>
    </xsl:copy>
  </xsl:template>
</xsl:stylesheet>
""")
tr = ET.XSLT(xslt)

doc2 = tr(root)
root2 = doc2.getroot()
pp(root2)

给你输出:

<project id="8dce5d94-4273-47ef-8d1b-0c7882f91caa" kpf_version="4">
  <livefolder id="8744bc67-1b9e-443d-ba9f-96e1d0007ba8" idref="707cd68a-33b5-4051-9e40-8ba686c2fdb8">Mooo</livefolder>
  <livefolder id="8744bc67-1b9e-443d-ba9f" idref="707cd68a-33b5-4051-9e40-8ba686c2fdb8"/>
  <preference-set idref="8dce5d94-4273-47ef-8d1b-0c7882f91caa">
    <boolean id="import_live">0</boolean>
  </preference-set>
</project>

<project>
  <livefolder/>
  <livefolder/>
  <preference-set>
    <boolean/>
  </preference-set>
</project>