Project

General

Profile

1 6620 aaronmk
#!/usr/bin/env python
2
# Translates a data dictionary spreadsheet to Redmine formatting
3
# Spreadsheet must have columns <Term>|...|Sources
4
# - <Term> can be any name
5
# Usage: self <spreadsheet >redmine
6
7
import csv
8
import re
9
import sys
10
11
# Spreadsheet format
12
source_sep = ', '
13
term_col = 0
14
15
##### URLs
16
17
def simplify_url(url): return re.sub(r'\(.*?\)', r'', url)
18
19
def url_term(url):
20 6625 aaronmk
    match = re.search(r'[\w:-]+$', url)
21 6620 aaronmk
    assert match
22 6622 aaronmk
    return match.group(0)
23 6620 aaronmk
24
##### Redmine
25
26
def redmine_url(text, url):
27
    if url: return '"'+text+'":'+url
28
    else: return text
29
30
def source2redmine_url(url):
31 6623 aaronmk
    if url: return redmine_url(url_term(url), simplify_url(url))
32
    else: return ''
33 6620 aaronmk
34
class RedmineTableWriter:
35
    '''Formats rows as a Redmine table'''
36
37
    def __init__(self, stream):
38
        self.stream = stream
39
40
    def writerow(self, row):
41
        self.stream.write(('|'.join(['']+row+['']))+'\n')
42
43
44
def main():
45
    # Determine column order
46
    reader = csv.reader(sys.stdin)
47
    header = reader.next()
48
    sources_col = header.index('Sources')
49
50
    # Translate input
51
    writer = RedmineTableWriter(sys.stdout)
52
    writer.writerow(['*Term*', '*Sources*'])
53
    for row in reader:
54
        term = row[term_col]
55
        sources = map(simplify_url, row[sources_col].split(source_sep))
56 6624 aaronmk
        sources_str = source_sep.join(map(source2redmine_url, sources))
57 6620 aaronmk
58
        writer.writerow([redmine_url(term, sources[0]), sources_str])
59
60
main()