Project

General

Profile

« Previous | Next » 

Revision 734

join: Use merge_rows() from new maps.py

View differences:

bin/join
2 2
# Inner-joins two map spreadsheets A->B and B->C to A->C
3 3

  
4 4
import csv
5
import os.path
5 6
import sys
6 7

  
7
def merge_rows(*rows):
8
    '''e.g. ['a','b'] + ['','y','z'] = ['a','b; y','z']'''
9
    def get(row, i):
10
        try: return row[i]
11
        except IndexError: return ''
12
    return ['; '.join(filter(lambda v: v != '', [get(row, i) for row in rows]))
13
    for i in xrange(max(map(len, rows)))]
8
sys.path.append(os.path.dirname(__file__)+"/../lib")
14 9

  
10
import maps
11

  
15 12
def main():
16 13
    try: _prog_name, map_1_path = sys.argv
17 14
    except ValueError:
......
40 37
            try:
41 38
                new = map_1[row[1]]
42 39
                row[1] = new[1] # mapping
43
                row[2:] = merge_rows(row[2:], new[2:]) # comments
40
                row[2:] = maps.merge_rows(row[2:], new[2:]) # comments
44 41
            except KeyError:
45 42
                row[2] = '** No join mapping for '+row[1]+' ** '+row[2]
46 43
                row[1] = ''

Also available in: Unified diff