annotate rest_tool.py @ 7:35b41070c20d draft

Deleted selected files
author bernhardlutz
date Thu, 03 Apr 2014 06:51:54 -0400
parents 9ee84d9fd3a7
children 3c1e862e8cd6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
1 #!/usr/bin/env python
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
2
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
3 import sys, os
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
4 import argparse
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
5
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
6 import readfile
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
7
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
8 txt_output=["cids", "aids", "sids", "synonyms" ]
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
9 csv_output=["assaysummary"]
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
10 check_for_id_type=["cids", "aids", "sids"]
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
11
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
12 def main(args):
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
13 url="http://pubchem.ncbi.nlm.nih.gov/rest/pug/"+args.type+"/"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
14 if args.type == "assay":
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
15 url+="aid/"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
16 elif args.type == "compound":
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
17 url+="cid/"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
18 elif args.type == "substance":
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
19 url+="sid/"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
20 if args.id_file is None:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
21 idstring=str(args.id)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
22 else:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
23 idlist=readfile.getListFromFile(args.id_file)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
24 idstring=",".join(idlist)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
25 url+=idstring+"/"+args.operation+"/"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
26 if args.operation in csv_output:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
27 url+="csv"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
28 elif args.operation in txt_output:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
29 url+="txt"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
30 else:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
31 url+="xml"
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
32 if args.operation in check_for_id_type and not args.id_type is None:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
33 url+="?"+args.operation+"_type="+args.id_type
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
34 print(url)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
35 data=readfile.getresult(url)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
36 outfile=args.outfile
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
37 outfile.write(data)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
38 outfile.close()
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
39
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
40 if __name__ == "__main__":
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
41 parser = argparse.ArgumentParser()
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
42 parser.add_argument('--type', type=str, required=True,
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
43 help="That you want BioAssay Compund ...")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
44 parser.add_argument('--id', type=str,
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
45 help="Specify the ID")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
46 parser.add_argument('--operation', type=str, required=True,
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
47 help="Specify the operation")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
48 parser.add_argument('--property-value', dest="property_value", type=str,
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
49 help="Specify the property")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
50 parser.add_argument('--id-type', dest="id_type", type=str,
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
51 help="Specify the property")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
52 parser.add_argument('--outfile', type=argparse.FileType('w'), required=True,
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
53 help="Specify one output file")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
54 parser.add_argument('--id-file', dest="id_file", type=argparse.FileType('r'),
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
55 help="Specify a file with a list of ids, one per line")
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
56 if len(sys.argv) < 8:
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
57 print "Too few arguments..."
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
58 parser.print_help()
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
59 exit(1)
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
60 args = parser.parse_args()
9ee84d9fd3a7 Uploaded
bernhardlutz
parents:
diff changeset
61 main( args )