我有一个格式类似于 docx 的 xml 文件,即:
<w:r>
<w:rPr>
<w:sz w:val="36"/>
<w:szCs w:val="36"/>
</w:rPr>
<w:t>BIG_TEXT</w:t>
</w:r>
我需要获取BIG_TEXT
源 xml 中的索引,例如:
from lxml import etree
text = open('/devel/tmp/doc2/word/document.xml', 'r').read()
root = etree.XML(text)
start = 0
for e in root.iter("*"):
if e.text:
offset = text.index(e.text, start)
l = len(e.text)
print 'Text "%s" at offset %s and len=%s' % (e.text, offset, l)
start = offset + l
我可以从当前index
+的位置开始新的搜索len(text)
,但是还有其他方法吗?例如,元素可能只有一个字符w
。它将找到标签文本的索引w
,但不是标签文本的索引w
。