annotate vcfPytools.py @ 0:f5d5eed73180 draft default tip

Imported from capsule None
author devteam
date Thu, 23 Jan 2014 12:31:34 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
1 #!/usr/bin/python
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
2
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
3 import os.path
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
4 import sys
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
5
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
6 __author__ = "alistair ward"
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
7 __version__ = "version 0.26"
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
8 __date__ = "february 2011"
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
9
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
10 def main():
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
11 usage = "Usage: vcfPytools.py [tool] [options]\n\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
12 "Available tools:\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
13 " annotate:\n\tAnnotate the vcf file with membership in other vcf files.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
14 " extract:\n\tExtract vcf records from a region.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
15 " filter:\n\tFilter the vcf file.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
16 " intersect:\n\tGenerate the intersection of two vcf files.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
17 " merge:\n\tMerge a list of vcf files.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
18 " multi:\n\tFind the intersections and unique fractions of multiple vcf files.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
19 " sort:\n\tSort a vcf file.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
20 " stats:\n\tGenerate statistics from a vcf file.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
21 " union:\n\tGenerate the union of two vcf files.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
22 " unique:\n\tGenerate the unique fraction from two vcf files.\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
23 " validate:\n\tValidate the input vcf file.\n\n" + \
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
24 "vcfPytools.py [tool] --help for information on a specific tool."
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
25
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
26 # Determine the requested tool.
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
27
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
28 if len(sys.argv) > 1:
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
29 tool = sys.argv[1]
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
30 else:
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
31 print >> sys.stderr, usage
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
32 exit(1)
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
33
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
34 if tool == "annotate":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
35 import annotate
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
36 success = annotate.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
37 elif tool == "extract":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
38 import extract
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
39 success = extract.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
40 elif tool == "filter":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
41 import filter
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
42 success = filter.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
43 elif tool == "intersect":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
44 import intersect
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
45 success = intersect.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
46 elif tool == "multi":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
47 import multi
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
48 success = multi.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
49 elif tool == "merge":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
50 import merge
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
51 success = merge.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
52 elif tool == "sort":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
53 import sort
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
54 success = sort.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
55 elif tool == "stats":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
56 import stats
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
57 success = stats.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
58 elif tool == "union":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
59 import union
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
60 success = union.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
61 elif tool == "unique":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
62 import unique
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
63 success = unique.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
64 elif tool == "test":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
65 import test
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
66 success = test.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
67 elif tool == "validate":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
68 import validate
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
69 success = validate.main()
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
70 elif tool == "--help" or tool == "-h" or tool == "?":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
71 print >> sys.stderr, usage
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
72 else:
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
73 print >> sys.stderr, "Unknown tool: ",tool
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
74 print >> sys.stderr, "\n", usage
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
75 exit(1)
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
76
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
77 # If program completed properly, terminate.
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
78
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
79 if success == 0: exit(0)
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
80
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
81 if __name__ == "__main__":
f5d5eed73180 Imported from capsule None
devteam
parents:
diff changeset
82 main()