File: spreadsheet_to_docbook.py

package info (click to toggle)
lyx 2.5.0~RC2-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 138,212 kB
  • sloc: cpp: 244,227; ansic: 106,398; xml: 72,791; python: 39,384; sh: 7,666; makefile: 6,586; pascal: 2,143; perl: 2,101; objc: 1,084; tcl: 163; sed: 16
file content (70 lines) | stat: -rw-r--r-- 2,572 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/usr/bin/python3

# file spreadsheet_to_docbook.py
# This file is part of LyX, the document processor.
# Licence details can be found in the file COPYING.

# author Thibaut Cuvelier & Kornel Benko

# Full author contact details are available in file CREDITS.

"""reformat output of ssconvert of a single spreadsheet to match the needs
of docbook5 table format .

Expects to read from file specified by sys.argv[1]
and output to to file specified by sys.argv[2]
"""

import re
import sys
import subprocess


def process_file(contents):
    # Scrap the header and the footer.
    contents = contents.split("<body>")[1]
    contents = contents.split("</body>")[0]

    # Gnumeric may generate more than one table, just take the first one.
    contents = contents.split("</table>")[0] + "\n</table>"

    # Convert the rest of the table to DocBook.
    contents = contents.replace("<p></p>", "")
    contents = contents.replace("<i>", "<emphasis>")
    contents = contents.replace("</i>", "</emphasis>")
    contents = contents.replace("<b>", "<emphasis role='bold'>")
    contents = contents.replace("</b>", "</emphasis>")
    contents = contents.replace("<u>", "<emphasis role='underline'>")
    contents = contents.replace("</u>", "</emphasis>")

    contents = re.sub(r"<font color=\"(.*)\">", "<phrase role='color \\1'>", contents)
    assert '<font' not in contents  # If this happens, implement something to catch these cases.
    contents = contents.replace("</font>", "</phrase>")  # Generates invalid XML if there are still font tags left...

    # If the table has a caption, then the right tag is <table>. Otherwise, it's <informaltable>.
    if '<caption>' not in contents:
        contents = contents.replace("<table", "<informaltable")
        contents = contents.replace("</table>", "</informaltable>")

    # Return the processed string.
    contents = contents.replace("\n\n", "\n")
    return contents


if __name__ == "__main__":
    if len(sys.argv) == 1:
        # Read from stdin, output to stdout.
        contents = sys.stdin.read()
        f = sys.stdout
    else:
        # Read from output of ssconvert
        assert len(sys.argv) == 3  # Script name, file to process, output file.
        proc = subprocess.Popen(["ssconvert", "--export-type=Gnumeric_html:xhtml", sys.argv[1], "fd://1"], stdout=subprocess.PIPE)
        f = open(sys.argv[2], 'w')
        sys.stdout = f  # Redirect stdout to the output file.
        contents = proc.stdout.read()

    # Process and output to stdout.
    print(process_file(contents))
    f.close()
    exit(0)