-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathfilter_muse.py
50 lines (37 loc) · 1.68 KB
/
filter_muse.py
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
import os, os.path, sys
import hgsc_vcf
SORTED_TIERS = ['Tier1', 'Tier2', 'Tier3', 'Tier4', 'Tier5']
def convert_record(record, convert, filter):
# converts in place
for con in convert:
if con in record['FILTER']:
# convert
record['INFO']['OF'] = ['|'.join(record['FILTER'])]
record['FILTER'] = ['PASS']
def main(args):
if args.level == 'all':
convert = SORTED_TIERS
filter = []
elif args.level in ['1','2','3','4','5']:
cut = int(args.level) - 1
convert = SORTED_TIERS[:cut]
filter = SORTED_TIERS[cut:]
else:
raise ValueError("%s is not a valid level" % args.level)
reader = hgsc_vcf.Reader(args.INPUT)
header = reader.header
header.add_header('##INFO=<ID=OF,Number=1,Type=String,Description="original tiering call for this variant in this sample">')
header.add_header('##COMMAND=<ID=filter_muse.py,Params="%s">' % ' '.join(sys.argv))
writer = hgsc_vcf.Writer(args.OUTPUT, header)
writer.write_header()
for record in reader:
convert_record(record, convert, filter)
writer.write_record(record)
if __name__ == '__main__':
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('--level', default = '5', type = str, help = 'one of 1,2,3,4,5,all. level represents the last level that will still be filtered, all implies that all levels will be retained (their filter columns will be converted to PASS).')
parser.add_argument('INPUT', type = argparse.FileType('r'), help = 'input file')
parser.add_argument('OUTPUT', type = argparse.FileType('w'), help = 'output file')
args = parser.parse_args()
main(args)