32 lines
924 B
Python
32 lines
924 B
Python
|
#!/usr/bin/python
|
||
|
|
||
|
import sys, zipfile, xml.dom.minidom
|
||
|
import StringIO
|
||
|
|
||
|
class OpenDocumentTextFile :
|
||
|
def __init__ (self, filepath) :
|
||
|
zip = zipfile.ZipFile(filepath)
|
||
|
self.content = xml.dom.minidom.parseString(zip.read("content.xml"))
|
||
|
|
||
|
def toString (self) :
|
||
|
""" Converts the document to a string. """
|
||
|
buffer = u""
|
||
|
for val in ["text:p", "text:h", "text:list"]:
|
||
|
for paragraph in self.content.getElementsByTagName(val) :
|
||
|
buffer += self.textToString(paragraph) + "\n"
|
||
|
return buffer
|
||
|
|
||
|
def textToString(self, element) :
|
||
|
buffer = u""
|
||
|
for node in element.childNodes :
|
||
|
if node.nodeType == xml.dom.Node.TEXT_NODE :
|
||
|
buffer += node.nodeValue
|
||
|
elif node.nodeType == xml.dom.Node.ELEMENT_NODE :
|
||
|
buffer += self.textToString(node)
|
||
|
return buffer
|
||
|
|
||
|
if __name__ == "__main__" :
|
||
|
s =StringIO.StringIO(file(sys.argv[1]).read())
|
||
|
odt = OpenDocumentTextFile(s)
|
||
|
print odt.toString().encode('ascii','replace')
|