Mercurial > repos > immport-devteam > flowcl
comparison getOntology.py @ 1:f70f75e89890 draft default tip
"planemo upload for repository https://github.com/ImmPortDB/immport-galaxy-tools/tree/master/flowtools/flowcl commit d59d95d2bc6a64eb5c37b8291a7c314754c2067f"
| author | azomics |
|---|---|
| date | Thu, 23 Jul 2020 08:50:18 -0400 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| 0:fb0ee82f686d | 1:f70f75e89890 |
|---|---|
| 1 #!/usr/bin/env python | |
| 2 ###################################################################### | |
| 3 # Copyright (c) 2016 Northrop Grumman. | |
| 4 # All rights reserved. | |
| 5 ###################################################################### | |
| 6 from __future__ import print_function | |
| 7 import sys | |
| 8 import os | |
| 9 | |
| 10 from collections import defaultdict | |
| 11 from argparse import ArgumentParser | |
| 12 from jinja2 import Environment, FileSystemLoader | |
| 13 | |
| 14 | |
| 15 def generate_flowCL_query(list_markers, list_types): | |
| 16 if (len(list_markers) != len(list_types)): | |
| 17 return("pb with headers") | |
| 18 query = [] | |
| 19 # go through both lists, remove fsc/ssc | |
| 20 for i in range(0, len(list_markers)): | |
| 21 if not list_markers[i].startswith("FSC") and not list_markers[i].startswith("SSC"): | |
| 22 query.append(list_markers[i].upper()) | |
| 23 query.append(list_types[i]) | |
| 24 # return concatenated string | |
| 25 return("".join(query)) | |
| 26 | |
| 27 | |
| 28 def run_flowCL(phenotype, output_file, output_dir, tool_dir): | |
| 29 os.mkdir(output_dir) | |
| 30 tool = "/".join([tool_dir, "getOntology.R"]) | |
| 31 output_txt = "".join([output_dir, "/flowCL_run_summary.txt"]) | |
| 32 output_table = "".join([output_dir, "/flowCL_table.txt"]) | |
| 33 output_pdf = "".join([output_dir, "/flowCL_res.pdf"]) | |
| 34 run_command = " ". join(["Rscript --slave --vanilla", tool, output_txt, phenotype]) | |
| 35 os.system(run_command) | |
| 36 | |
| 37 table = defaultdict(list) | |
| 38 labels = [] | |
| 39 nb_match = 0 | |
| 40 if os.path.isfile(output_txt): | |
| 41 with open(output_txt, "r") as txt: | |
| 42 check = txt.readline().strip() | |
| 43 if (not check): | |
| 44 sys.exit(2) | |
| 45 else: | |
| 46 i = -1 | |
| 47 for lines in txt: | |
| 48 data = lines.strip("\n").split("\"") | |
| 49 if data[0].strip(): | |
| 50 labels.append(data[0].strip()) | |
| 51 i += 1 | |
| 52 if data[0].startswith("Score"): | |
| 53 count_matches = data[1].split(") ") | |
| 54 nb_match = len(count_matches) - 1 | |
| 55 table[i].append(data[1]) | |
| 56 else: | |
| 57 sys.stderr.write("There are no results with this query. Please check your markers if you believe there should be.") | |
| 58 sys.exit(2) | |
| 59 | |
| 60 with open(output_table, "w") as tbl: | |
| 61 tbl.write("1\t2\nQuery\t" + phenotype + "\n") | |
| 62 for j in table: | |
| 63 newline = " ".join(table[j]) | |
| 64 for k in range(1, nb_match + 1): | |
| 65 cur_stg = "".join([str(k+1), ")"]) | |
| 66 new_stg = "".join(["<br>", cur_stg]) | |
| 67 newline = newline.replace(cur_stg, new_stg) | |
| 68 | |
| 69 if labels[j] == "Cell ID": | |
| 70 cls = newline.split(" ") | |
| 71 for m in range(0, len(cls)): | |
| 72 if cls[m].startswith("CL"): | |
| 73 cl_id = cls[m].replace("_", ":") | |
| 74 link = "".join(['<a href="http://www.immport-labs.org/immport-ontology/public/home/home/', cl_id, '" target="_blank">']) | |
| 75 cls[m] = "".join([link, cls[m], "</a>"]) | |
| 76 newline = " ".join(cls) | |
| 77 tbl.write("\t".join([labels[j], newline]) + "\n") | |
| 78 | |
| 79 get_graph = " ".join(["mv flowCL_results/*.pdf", output_pdf]) | |
| 80 os.system(get_graph) | |
| 81 | |
| 82 env = Environment(loader=FileSystemLoader(tool_dir + "/templates")) | |
| 83 template = env.get_template("flowCL.template") | |
| 84 | |
| 85 real_directory = output_dir.replace("/job_working_directory", "") | |
| 86 context = {'outputDirectory': real_directory} | |
| 87 overview = template.render(**context) | |
| 88 with open(output_file, "w") as outf: | |
| 89 outf.write(overview) | |
| 90 return | |
| 91 | |
| 92 | |
| 93 if __name__ == "__main__": | |
| 94 parser = ArgumentParser( | |
| 95 prog="getOntology", | |
| 96 description="runs flowCL on a set of markers.") | |
| 97 | |
| 98 parser.add_argument( | |
| 99 '-m', | |
| 100 dest="markers", | |
| 101 required=True, | |
| 102 action='append', | |
| 103 help="marker queries.") | |
| 104 | |
| 105 parser.add_argument( | |
| 106 '-y', | |
| 107 dest="marker_types", | |
| 108 required=True, | |
| 109 action='append', | |
| 110 help="marker queries.") | |
| 111 | |
| 112 parser.add_argument( | |
| 113 '-o', | |
| 114 dest="output_file", | |
| 115 required=True, | |
| 116 help="Name of the output html file.") | |
| 117 | |
| 118 parser.add_argument( | |
| 119 '-d', | |
| 120 dest="output_dir", | |
| 121 required=True, | |
| 122 help="Path to the html supporting directory") | |
| 123 | |
| 124 parser.add_argument( | |
| 125 '-t', | |
| 126 dest="tool_dir", | |
| 127 required=True, | |
| 128 help="Path to the tool directory") | |
| 129 | |
| 130 args = parser.parse_args() | |
| 131 | |
| 132 markers = [m.strip() for m in args.markers] | |
| 133 query = generate_flowCL_query(markers, args.marker_types) | |
| 134 run_flowCL(query, args.output_file, args.output_dir, args.tool_dir) |
