annotate imgtconvert.py @ 3:191d0df65d28 draft

Uploaded
author davidvanzessen
date Tue, 11 Mar 2014 09:24:29 -0400
parents 477cab9c32d1
children 021d39f6bb0e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
1 import pandas as pd
3
191d0df65d28 Uploaded
davidvanzessen
parents: 2
diff changeset
2 try:
191d0df65d28 Uploaded
davidvanzessen
parents: 2
diff changeset
3 pd.options.mode.chained_assignment = None # default='warn'
191d0df65d28 Uploaded
davidvanzessen
parents: 2
diff changeset
4 except:
191d0df65d28 Uploaded
davidvanzessen
parents: 2
diff changeset
5 pass
0
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
6 import re
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
7 import argparse
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
8 import os
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
9
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
10 def stop_err( msg, ret=1 ):
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
11 sys.stderr.write( msg )
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
12 sys.exit( ret )
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
13
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
14 #docs.python.org/dev/library/argparse.html
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
15 parser = argparse.ArgumentParser()
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
16 parser.add_argument("--input", help="Input folder with files")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
17 parser.add_argument("--output", help="Output file")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
18
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
19 args = parser.parse_args()
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
20
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
21 old_summary_columns = [u'Sequence ID', u'JUNCTION frame', u'V-GENE and allele', u'D-GENE and allele', u'J-GENE and allele', u'CDR1-IMGT length', u'CDR2-IMGT length', u'CDR3-IMGT length', u'Orientation']
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
22 old_sequence_columns = [u'CDR1-IMGT', u'CDR2-IMGT', u'CDR3-IMGT']
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
23 old_junction_columns = [u'JUNCTION']
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
24
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
25 added_summary_columns = [u'Functionality', u'V-REGION identity %', u'V-REGION identity nt', u'D-REGION reading frame', u'AA JUNCTION', u'Functionality comment', u'Sequence']
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
26 added_sequence_columns = [u'FR1-IMGT', u'FR2-IMGT', u'FR3-IMGT', u'CDR3-IMGT', u'JUNCTION', u'J-REGION', u'FR4-IMGT']
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
27 added_junction_columns = [u"P3'V-nt nb", u'N1-REGION-nt nb', u"P5'D-nt nb", u"P3'D-nt nb", u'N2-REGION-nt nb', u"P5'J-nt nb", u"3'V-REGION trimmed-nt nb", u"5'D-REGION trimmed-nt nb", u"3'D-REGION trimmed-nt nb", u"5'J-REGION trimmed-nt nb"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
28
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
29 inputFolder = args.input
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
30
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
31 dirContents = os.listdir(inputFolder)
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
32 if len(dirContents) == 1:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
33 inputFolder = os.path.join(inputFolder, dirContents[0])
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
34 if os.path.isdir(inputFolder):
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
35 print "is dir"
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
36 dirContents = os.listdir(inputFolder)
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
37 files = sorted([os.path.join(inputFolder, f) for f in dirContents])
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
38
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
39 if len(files) % 3 is not 0:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
40 stop_err("Files in zip not a multiple of 3, it should contain the all the 1_, 5_ and 6_ files for a sample")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
41 import sys
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
42 sys.exit()
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
43
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
44 triplets = []
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
45 step = len(files) / 3
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
46 for i in range(0, step):
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
47 triplets.append((files[i], files[i + step], files[i + step + step]))
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
48
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
49 outFile = args.output
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
50
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
51 fSummary = pd.read_csv(triplets[0][0], sep="\t")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
52 fSequence = pd.read_csv(triplets[0][1], sep="\t")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
53 fJunction = pd.read_csv(triplets[0][2], sep="\t")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
54 tmp = fSummary[["Sequence ID", "JUNCTION frame", "V-GENE and allele", "D-GENE and allele", "J-GENE and allele"]]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
55
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
56 tmp["CDR1 Seq"] = fSequence["CDR1-IMGT"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
57 tmp["CDR1 Length"] = fSummary["CDR1-IMGT length"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
58
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
59 tmp["CDR2 Seq"] = fSequence["CDR2-IMGT"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
60 tmp["CDR2 Length"] = fSummary["CDR2-IMGT length"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
61
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
62 tmp["CDR3 Seq"] = fSequence["CDR3-IMGT"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
63 tmp["CDR3 Length"] = fSummary["CDR3-IMGT length"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
64
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
65 tmp["CDR3 Seq DNA"] = fJunction["JUNCTION"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
66 tmp["CDR3 Length DNA"] = '1'
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
67 tmp["Strand"] = fSummary["Orientation"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
68 tmp["CDR3 Found How"] = 'a'
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
69
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
70 for col in added_summary_columns:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
71 tmp[col] = fSummary[col]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
72
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
73 for col in added_sequence_columns:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
74 tmp[col] = fSequence[col]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
75
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
76 for col in added_junction_columns:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
77 tmp[col] = fJunction[col]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
78
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
79 outFrame = tmp
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
80
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
81 for triple in triplets[1:]:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
82 fSummary = pd.read_csv(triple[0], sep="\t")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
83 fSequence = pd.read_csv(triple[1], sep="\t")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
84 fJunction = pd.read_csv(triple[2], sep="\t")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
85
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
86 tmp = fSummary[["Sequence ID", "JUNCTION frame", "V-GENE and allele", "D-GENE and allele", "J-GENE and allele"]]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
87
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
88 tmp["CDR1 Seq"] = fSequence["CDR1-IMGT"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
89 tmp["CDR1 Length"] = fSummary["CDR1-IMGT length"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
90
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
91 tmp["CDR2 Seq"] = fSequence["CDR2-IMGT"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
92 tmp["CDR2 Length"] = fSummary["CDR2-IMGT length"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
93
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
94 tmp["CDR3 Seq"] = fSequence["CDR3-IMGT"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
95 tmp["CDR3 Length"] = fSummary["CDR3-IMGT length"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
96
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
97 tmp["CDR3 Seq DNA"] = fJunction["JUNCTION"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
98 tmp["CDR3 Length DNA"] = '1'
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
99 tmp["Strand"] = fSummary["Orientation"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
100 tmp["CDR3 Found How"] = 'a'
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
101
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
102 for col in added_summary_columns:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
103 tmp[col] = fSummary[col]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
104
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
105 for col in added_sequence_columns:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
106 tmp[col] = fSequence[col]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
107
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
108 for col in added_junction_columns:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
109 tmp[col] = fJunction[col]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
110
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
111 outFrame = outFrame.append(tmp)
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
112
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
113 outFrame.columns = [u'ID', u'VDJ Frame', u'Top V Gene', u'Top D Gene', u'Top J Gene', u'CDR1 Seq', u'CDR1 Length', u'CDR2 Seq', u'CDR2 Length', u'CDR3 Seq', u'CDR3 Length', u'CDR3 Seq DNA', u'CDR3 Length DNA', u'Strand', u'CDR3 Found How', u'Functionality', 'V-REGION identity %', 'V-REGION identity nt', 'D-REGION reading frame', 'AA JUNCTION', 'Functionality comment', 'Sequence', 'FR1-IMGT', 'FR2-IMGT', 'FR3-IMGT', 'CDR3-IMGT', 'JUNCTION', 'J-REGION', 'FR4-IMGT', 'P3V-nt nb', 'N1-REGION-nt nb', 'P5D-nt nb', 'P3D-nt nb', 'N2-REGION-nt nb', 'P5J-nt nb', '3V-REGION trimmed-nt nb', '5D-REGION trimmed-nt nb', '3D-REGION trimmed-nt nb', '5J-REGION trimmed-nt nb']
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
114
1
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
115 #vPattern = re.compile(r"|TRBV[0-9]{1,2}-?[0-9]?") #mouse
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
116 #vPattern = re.compile(r"IGHV[1-9]-[0-9ab]+-?[1-9]?") #human
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
117 vPattern = re.compile(r"IGHV[1-9]-[0-9ab]+-?[1-9]?|TRBV[0-9]{1,2}-?[0-9]?") #mouse and human
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
118
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
119 #dPattern = re.compile(r"TRBD1|TRBD2") #mouse
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
120 #dPattern = re.compile(r"IGHD[1-9]-[0-9ab]+") #human
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
121 dPattern = re.compile(r"IGHD[1-9]-[0-9ab]+|TRBD1|TRBD2") #mouse and human
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
122
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
123
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
124 #jPattern = re.compile(r"TRBJ[12]-[1-7]") #mouse
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
125 #jPattern = re.compile(r"IGHJ[1-6]") #human
4405849aa053 Uploaded
davidvanzessen
parents: 0
diff changeset
126 jPattern = re.compile(r"IGHJ[1-6]|TRBJ[12]-[1-7]") #mouse and human
0
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
127
3
191d0df65d28 Uploaded
davidvanzessen
parents: 2
diff changeset
128
0
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
129 def filterGenes(s, pattern):
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
130 if type(s) is not str:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
131 return "NA"
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
132 res = pattern.search(s)
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
133 if res:
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
134 return res.group(0)
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
135 return "NA"
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
136
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
137
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
138 outFrame["Top V Gene"] = outFrame["Top V Gene"].apply(lambda x: filterGenes(x, vPattern))
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
139 outFrame["Top D Gene"] = outFrame["Top D Gene"].apply(lambda x: filterGenes(x, dPattern))
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
140 outFrame["Top J Gene"] = outFrame["Top J Gene"].apply(lambda x: filterGenes(x, jPattern))
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
141
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
142
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
143
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
144 tmp = outFrame["VDJ Frame"]
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
145 tmp = tmp.replace("in-frame", "In-frame")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
146 tmp = tmp.replace("null", "Out-of-frame")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
147 tmp = tmp.replace("out-of-frame", "Out-of-frame")
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
148 outFrame["VDJ Frame"] = tmp
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
149 outFrame["CDR3 Length DNA"] = outFrame["CDR3 Seq DNA"].map(str).map(len)
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
150 safeLength = lambda x: len(x) if type(x) == str else 0
f8ba6ab5514b Uploaded
davidvanzessen
parents:
diff changeset
151 outFrame = outFrame[(outFrame["CDR3 Seq DNA"].map(safeLength) > 0) & (outFrame["Top V Gene"] != "NA") & (outFrame["Top D Gene"] != "NA") & (outFrame["Top J Gene"] != "NA")] #filter out weird rows?
3
191d0df65d28 Uploaded
davidvanzessen
parents: 2
diff changeset
152 outFrame.to_csv(outFile, sep="\t", index=False, index_label="index")