|
0
|
1 import sys, csv, argparse, os
|
|
|
2
|
|
|
3 from bl.vl.kb import KnowledgeBase as KB
|
|
|
4 import bl.vl.utils.ome_utils as vlu
|
|
|
5 from bl.vl.utils import get_logger, LOG_LEVELS
|
|
|
6
|
|
|
7
|
|
|
8 def make_parser():
|
|
|
9 parser = argparse.ArgumentParser(description='set parents of the selected individuals to None')
|
|
|
10 parser.add_argument('--logfile', type=str, help='log file (default=stderr)')
|
|
|
11 parser.add_argument('--loglevel', type=str, choices=LOG_LEVELS,
|
|
|
12 help='logging level (default=INFO)', default='INFO')
|
|
|
13 parser.add_argument('-H', '--host', type=str, help='omero hostname')
|
|
|
14 parser.add_argument('-U', '--user', type=str, help='omero user')
|
|
|
15 parser.add_argument('-P', '--passwd', type=str, help='omero password')
|
|
|
16 parser.add_argument('--in_file', type=str, required=True,
|
|
|
17 help='list of the individuals')
|
|
|
18 parser.add_argument('--out_file', type=str, required=True,
|
|
|
19 help='output file')
|
|
|
20 return parser
|
|
|
21
|
|
|
22
|
|
|
23 def main(argv):
|
|
|
24 parser = make_parser()
|
|
|
25 args = parser.parse_args(argv)
|
|
|
26
|
|
|
27 logger = get_logger('drop_parental_info', level=args.loglevel,
|
|
|
28 filename=args.logfile)
|
|
|
29
|
|
|
30 try:
|
|
|
31 host = args.host or vlu.ome_host()
|
|
|
32 user = args.user or vlu.ome_user()
|
|
|
33 passwd = args.passwd or vlu.ome_passwd()
|
|
|
34 except ValueError, ve:
|
|
|
35 logger.critical(ve)
|
|
|
36 sys.exit(ve)
|
|
|
37
|
|
|
38 kb = KB(driver='omero')(host, user, passwd)
|
|
|
39
|
|
|
40 logger.info('Retrieving individuals')
|
|
|
41 inds = kb.get_objects(kb.Individual)
|
|
|
42 logger.info('Retrieved %d individuals' % len(inds))
|
|
|
43 inds_lookup = {}
|
|
|
44 for i in inds:
|
|
|
45 inds_lookup[i.id] = i
|
|
|
46
|
|
|
47 with open(args.in_file) as in_file:
|
|
|
48 reader = csv.DictReader(in_file, delimiter='\t')
|
|
|
49 records = []
|
|
|
50 for row in reader:
|
|
|
51 try:
|
|
|
52 # The 'individual' : inds_lookup[row['individual']].id
|
|
|
53 # is quite redundant but is a usefull check in order
|
|
|
54 # to filter wrong VIDs
|
|
|
55 record = {'individual' : inds_lookup[row['individual']].id,
|
|
|
56 'father' : 'None',
|
|
|
57 'mother' : 'None'}
|
|
|
58 records.append(record)
|
|
|
59 except KeyError, ke:
|
|
|
60 logger.warning('Individual with VID %s does not exist, skipping line' % ke)
|
|
|
61
|
|
|
62 with open(args.out_file, 'w') as out_file:
|
|
|
63 writer = csv.DictWriter(out_file, ['individual', 'father', 'mother'],
|
|
|
64 delimiter = '\t')
|
|
|
65 writer.writeheader()
|
|
|
66 writer.writerows(records)
|
|
|
67
|
|
|
68 if __name__ == '__main__':
|
|
|
69 main(sys.argv[1:])
|