annotate rankfilter_GCMS/pdfread.py @ 62:9bd2597c8851 default tip

r
author pieter.lukasse@wur.nl
date Fri, 06 Feb 2015 15:49:26 +0100
parents d685210eef3e
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
1 """
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
2 Copyright (C) 2011 by Velitchka Mihaleva, Wageningen University
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
3
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
4 Permission is hereby granted, free of charge, to any person obtaining a copy
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
5 of this software and associated documentation files (the "Software"), to deal
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
6 in the Software without restriction, including without limitation the rights
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
7 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
8 copies of the Software, and to permit persons to whom the Software is
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
9 furnished to do so, subject to the following conditions:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
10
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
11 The above copyright notice and this permission notice shall be included in
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
12 all copies or substantial portions of the Software.
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
13
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
14 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
15 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
16 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
17 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
18 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
19 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
20 THE SOFTWARE.
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
21 """
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
22
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
23 import sys
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
24 import csv
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
25
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
26 def getPDF(filename, print_progress):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
27 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
28 Parses NIST PDF file
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
29 @param filename: PDF file to parse
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
30 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
31 NistInput = {}
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
32 NistInput_missed = {}
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
33 nist_input = open(filename, 'r').read()
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
34
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
35 hitid = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
36 rt = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
37 name = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
38 forward = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
39 cas = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
40 reverse = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
41 prob = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
42 lib_id = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
43 nist_id = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
44 missed_compounds = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
45 rt_missed_compounds = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
46 formula = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
47
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
48 hit_list = nist_input.split('** Search Report Page 1 of 1 **')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
49 hit_list.pop(0)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
50 #number_hits = range(10)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
51 line_id = 0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
52 for line in hit_list:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
53 line = line.strip().translate(None, '\r')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
54 if line != '':
26
637830ac8bcd added validation in metexp to tabular tool; added workaround/fix for L and D compound types
pieter.lukasse@wur.nl
parents: 0
diff changeset
55 hits = line.replace('\n', ' ').replace('\x0c', '').replace('^L', '').split('Hit') #solution? : if we wouldn't replace the \n by ' ' but by some special sign, then reading formula would be simpler!
637830ac8bcd added validation in metexp to tabular tool; added workaround/fix for L and D compound types
pieter.lukasse@wur.nl
parents: 0
diff changeset
56 #strange....code seems fine actually...debug! See test/data/download.pdf
637830ac8bcd added validation in metexp to tabular tool; added workaround/fix for L and D compound types
pieter.lukasse@wur.nl
parents: 0
diff changeset
57 # strange thing is that it looks like the new line does not end up in the text file, eventhough it looks like there is a new line in the pdf...perhaps a bug in the pdf2text command in linux?
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
58 spec_id = hits.pop(0).split(' ')[1]
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
59 j = 0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
60 for hh in hits:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
61 cell = hh.split(';')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
62 if print_progress == True:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
63 print 'Processing line: ', line_id, ' with length: ', len(cell), ':\n\t', cell
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
64 line_id += 1
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
65 if len(cell) == 7: # the compound has CAS number
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
66 if len(cell[1].split(':')) == 2:
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
67 forward.append((cell[1].split(':')[1]).strip())
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
68 # indication that the name contains the ":". Should join the cells of name_tmp from 1 till end
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
69 if len(cell[0].split(':')) > 2:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
70 name_tmp = ':'.join(cell[0].split(':')[1:])
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
71 else:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
72 name_tmp = cell[0].split(':')[1]
26
637830ac8bcd added validation in metexp to tabular tool; added workaround/fix for L and D compound types
pieter.lukasse@wur.nl
parents: 0
diff changeset
73
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
74 name.append(name_tmp.replace(" ", " ").strip())
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
75 name_tmp = name_tmp.strip().split(' ')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
76 if name_tmp:
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
77 # if the name ends with a word that starts with C, F or H, then assume this last word is a formula:
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
78 if name_tmp[-1][0] == 'C' or name_tmp[-1][0] == 'F' or name_tmp[-1][0] == 'H':
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
79 formule = (name_tmp[-1])
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
80 else:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
81 formule = ('not_def')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
82 else:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
83 formule = ('not_def')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
84 formula.append(formule.replace(" ", " "))
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
85 reverse.append((cell[2].split(':')[1]).strip())
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
86 prob.append(cell[3].split(' ')[2].replace('%', ''))
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
87 cas.append((cell[4].split(':')[1]).strip())
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
88 lib_id.append((cell[5].split(':')[1]).strip())
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
89 nist_id.append(cell[6].split(':')[1].replace('.', '').strip())
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
90 j = j + 1
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
91 else:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
92 missed_compounds.append(hh)
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
93 rt_missed_compounds.append(spec_id)
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
94
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
95 elif len(cell) == 6: # the compound has no CAS number
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
96 if len(cell[1].split(':')) == 2:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
97
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
98 forward.append((cell[1].split(':')[1]).strip())
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
99 # indication that the name contains the ":". Should join the cells of name_tmp from 1 till end
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
100 if len(cell[0].split(':')) > 2:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
101 name_tmp = ':'.join(cell[0].split(':')[1:])
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
102 else:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
103 name_tmp = cell[0].split(':')[1]
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
104
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
105 name.append(name_tmp.replace(" ", " ").strip())
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
106 name_tmp = name_tmp.strip().split(' ')
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
107 if name_tmp:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
108 # if the name ends with a word that starts with C, F or H, then assume this last word is a formula:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
109 if name_tmp[-1][0] == 'C' or name_tmp[-1][0] == 'F' or name_tmp[-1][0] == 'H':
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
110 formule = (name_tmp[-1])
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
111 else:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
112 formule = ('not_def')
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
113 else:
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
114 formule = ('not_def')
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
115 formula.append(formule.replace(" ", " "))
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
116 reverse.append((cell[2].split(':')[1]).strip())
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
117 prob.append(cell[3].split(' ')[2].replace('%', ''))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
118 cas.append('undef')
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
119 lib_id.append((cell[4].split(':')[1]).strip())
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
120 nist_id.append(cell[5].split(':')[1].replace('.', '').strip())
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
121 j = j + 1
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
122
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
123 else:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
124 missed_compounds.append(hh)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
125 rt_missed_compounds.append(spec_id)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
126
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
127 else: # Missing columns, report and quit
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
128 missed_compounds.append(hh)
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
129 rt_missed_compounds.append(spec_id)
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
130
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
131 for _ in range(j):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
132 hitid.append(str(spec_id.replace(" ", " ")))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
133 rt.append(str(float(spec_id.split('-')[3]) / 1e+06))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
134
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
135 NistInput['ID'] = hitid
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
136 NistInput['R.T.'] = rt
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
137 NistInput['Name'] = name
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
138 NistInput['CAS'] = cas
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
139 NistInput['Formula'] = formula
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
140 NistInput['Forward'] = forward
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
141 NistInput['Reverse'] = reverse
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
142 NistInput['Probability'] = prob
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
143 NistInput['Library'] = lib_id
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
144 NistInput['Library ID'] = nist_id
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
145 NistInput_missed['Missed Compounds'] = missed_compounds
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
146 NistInput_missed['RT missed Compounds'] = rt_missed_compounds
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
147
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
148 return NistInput, NistInput_missed
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
149
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
150
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
151 def convert_pdftotext2tabular(filename, output_file, error_file, print_progress):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
152 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
153 Converts NIST PDF file to tabular format
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
154 @param filename: PDF file to parse
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
155 @param output_file: output file for the hits
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
156 @param error_file: output file for failed hits
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
157 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
158 [HitList, HitList_missed] = getPDF(filename, print_progress)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
159 # save Hitlist as tab seperate file
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
160 Hitlist_as_text = "\t".join(HitList.keys()) + "\n"
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
161 Hitlist_array_of_array = ([HitList[row] for row in HitList.keys()])
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
162 Hitlist_as_text += str("\n".join(["\t".join(e) for e in zip(*Hitlist_array_of_array)]))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
163 output_fh = open(output_file, 'wb')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
164 output_fh.write(Hitlist_as_text)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
165 output_fh.close()
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
166
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
167 out_missed_pdf = open(error_file, 'wb')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
168 for x, y in zip(HitList_missed['Missed Compounds'], HitList_missed['RT missed Compounds']):
61
d685210eef3e fix in pdftotabular tool
pieter.lukasse@wur.nl
parents: 60
diff changeset
169 out_missed_pdf.write("Line with incorrect format or unexpected number of fields:\n")
0
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
170 out_missed_pdf.write('%s\n' % '\t'.join([y, x]))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
171 out_missed_pdf.close()
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
172
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
173
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
174 def read_tabular(in_csv):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
175 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
176 Parses a tab-separated file returning a dictionary with named columns
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
177 @param in_csv: input filename to be parsed
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
178 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
179 data = list(csv.reader(open(in_csv, 'rU'), delimiter='\t'))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
180 header = data.pop(0)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
181 # Create dictionary with column name as key
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
182 output = {}
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
183 for index in xrange(len(header)):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
184 output[header[index]] = [row[index] for row in data]
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
185 return output
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
186
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
187
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
188 def read_tabular_old(filename):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
189 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
190 Function to read tabular format (created by convert_pdftotext2tabular)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
191 and output a dict with header of columns as key and value is columns of tabular as list
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
192 @param filename: tabular file to read
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
193 '''
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
194 input_fh = None
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
195 try:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
196 input_fh = open(filename, 'r')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
197 except IOError, error:
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
198 raise error
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
199 colnames = input_fh.readline().strip().split('\t')
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
200 cells = []
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
201 for line in input_fh.readlines():
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
202 cells.append(line.strip().split('\t'))
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
203 #transform from row oriented structure to column oriented structure
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
204 cells = zip(*cells)
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
205 #store the list of list in form of final output
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
206 RankFilterGC_format = {}
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
207 for colnumber in range(len(colnames)):
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
208 RankFilterGC_format[colnames[colnumber]] = cells[colnumber]
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
209 return RankFilterGC_format
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
210
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
211
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
212 if __name__ == '__main__':
9d5f4f5f764b Initial commit to toolshed
pieter.lukasse@wur.nl
parents:
diff changeset
213 convert_pdftotext2tabular(sys.argv[1], sys.argv[2], sys.argv[3], True)