Mercurial > repos > peterjc > venn_list
changeset 8:ee50d9ef9d69 draft
v0.0.11 Python 3 compatible print; capture script version
author | peterjc |
---|---|
date | Thu, 11 May 2017 06:21:20 -0400 (2017-05-11) |
parents | ba31415fedc5 |
children | 5c5a9ce6c46d |
files | tools/venn_list/README.rst tools/venn_list/venn_list.py tools/venn_list/venn_list.xml |
diffstat | 3 files changed, 31 insertions(+), 26 deletions(-) [+] |
line wrap: on
line diff
--- a/tools/venn_list/README.rst Thu Feb 02 11:45:35 2017 -0500 +++ b/tools/venn_list/README.rst Thu May 11 06:21:20 2017 -0400 @@ -75,6 +75,10 @@ v0.0.10 - Updated to point at Biopython 1.67 (latest version in Tool Shed). - Explicit dependency on ``galaxy_sequence_utils``. - Python style updates (internal change only). +v0.0.11 - Use ``<command detect_errors="aggressive">`` (internal change only). + - Single quote command line arguments (internal change only) + - Python 3 compatible print function. + - Capture python script version when run from Galaxy. ======= ====================================================================== @@ -91,17 +95,17 @@ Planemo commands (which requires you have set your Tool Shed access details in ``~/.planemo.yml`` and that you have access rights on the Tool Shed):: - $ planemo shed_update -t testtoolshed --check_diff ~/repositories/pico_galaxy/tools/venn_list/ + $ planemo shed_update -t testtoolshed --check_diff tools/venn_list/ ... or:: - $ planemo shed_update -t toolshed --check_diff ~/repositories/pico_galaxy/tools/venn_list/ + $ planemo shed_update -t toolshed --check_diff tools/venn_list/ ... To just build and check the tar ball, use:: - $ planemo shed_upload --tar_only ~/repositories/pico_galaxy/tools/venn_list/ + $ planemo shed_upload --tar_only tools/venn_list/ ... $ tar -tzf shed_upload.tar.gz tools/venn_list/README.rst
--- a/tools/venn_list/venn_list.py Thu Feb 02 11:45:35 2017 -0500 +++ b/tools/venn_list/venn_list.py Thu May 11 06:21:20 2017 -0400 @@ -1,16 +1,20 @@ #!/usr/bin/env python """Plot up to 3-way Venn Diagram using R limma vennDiagram (via rpy) -This script is copyright 2010 by Peter Cock, The James Hutton Institute +This script is copyright 2010-2017 by Peter Cock, The James Hutton Institute (formerly SCRI), UK. All rights reserved. -See accompanying text file for licence details (MIT/BSD style). -This is version 0.0.8 of the script. +See accompanying text file for licence details (MIT License). """ +from __futute__ import print_function import sys +if "-v" in sys.argv or "--version" in sys.argv: + print("v0.0.11") + sys.exit(0) + try: import rpy except ImportError: @@ -37,7 +41,7 @@ set_data.append(tuple(sys.argv[10:13])) pdf_file = sys.argv[-1] n = len(set_data) -print "Doing %i-way Venn Diagram" % n +print("Doing %i-way Venn Diagram" % n) def load_ids(filename, filetype): @@ -77,6 +81,7 @@ else: sys.exit("Unexpected ID %s in %s file %s" % (name, filetype, filename)) + if all_file in ["", "-", '""', '"-"']: # Load without white list sets = [set(load_ids(f, t)) for (f, t, c) in set_data] @@ -84,14 +89,14 @@ all_ids = set() for s in sets: all_ids.update(s) - print "Inferred total of %i IDs" % len(all_ids) + print("Inferred total of %i IDs" % len(all_ids)) else: all_ids = set(load_ids(all_file, all_type)) - print "Total of %i IDs" % len(all_ids) + print("Total of %i IDs" % len(all_ids)) sets = [set(load_ids_whitelist(f, t, all_ids)) for (f, t, c) in set_data] for s, (f, t, c) in zip(sets, set_data): - print "%i in %s" % (len(s), c) + print("%i in %s" % (len(s), c)) # Now call R library to draw simple Venn diagram try: @@ -102,7 +107,7 @@ rpy.r('vc <- vennCounts(groups)') # Populate the 2^n classes with real counts # Don't make any assumptions about the class order - # print rpy.r('vc') + # print(rpy.r('vc')) for index, row in enumerate(rpy.r('vc[,%s]' % cols)): if isinstance(row, int) or isinstance(row, float): # Hack for rpy being too clever for single element row @@ -114,7 +119,7 @@ else: names = names.difference(s) rpy.r('vc[%i,"Counts"] <- %i' % (index + 1, len(names))) - # print rpy.r('vc') + # print(rpy.r('vc')) if n == 1: # Single circle, don't need to add (Total XXX) line names = [c for (t, f, c) in set_data] @@ -131,4 +136,4 @@ except Exception, exc: sys.exit("%s" % str(exc)) rpy.r.quit(save="no") -print "Done" +print("Done")
--- a/tools/venn_list/venn_list.xml Thu Feb 02 11:45:35 2017 -0500 +++ b/tools/venn_list/venn_list.xml Thu May 11 06:21:20 2017 -0400 @@ -1,28 +1,24 @@ -<tool id="venn_list" name="Venn Diagram" version="0.0.10"> +<tool id="venn_list" name="Venn Diagram" version="0.0.11"> <description>from lists</description> <requirements> <requirement type="package" version="1.0.1">galaxy_sequence_utils</requirement> - <requirement type="python-module">rpy</requirement> - <requirement type="python-module">Bio</requirement> <requirement type="package" version="1.0.3">rpy</requirement> <requirement type="package" version="3.25.3">limma</requirement> <requirement type="package" version="1.67">biopython</requirement> </requirements> - <stdio> - <!-- Anything other than zero is an error --> - <exit_code range="1:" /> - <exit_code range=":-1" /> - </stdio> - <command interpreter="python"> -venn_list.py + <version_command> +python $__tool_directory__/venn_list.py --version + </version_comman> + <command detect_errors="aggressive"> +python $__tool_directory__/venn_list.py #if $universe.type_select=="implicit": - - #else: - "$main" $main.ext + '$main' $main.ext #end if -"$main_lab" +'$main_lab' #for $s in $sets: - "$s.set" $s.set.ext "$s.lab" + '$s.set' $s.set.ext '$s.lab' #end for $PDF </command>