Mercurial > repos > galaxyp > maxquant_mqpar
annotate init.py @ 0:a52165553917 draft
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
| author | galaxyp | 
|---|---|
| date | Fri, 19 Jul 2019 19:13:52 -0400 | 
| parents | |
| children | b95d333b4a3f | 
| rev | line source | 
|---|---|
| 0 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 1 #!/usr/bin/env python3 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 2 """Initialize MaxQuant tool for use with a new version of | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 3 modifications/enzymes.xml. | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 4 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 5 TODO: Append function: only add modifications that are not | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 6 already present, add modification entries to conda maxquant | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 7 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 8 Authors: Damian Glaetzer <d.glaetzer@mailbox.org> | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 9 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 10 Usage: init.py [-a] [-m MODS_FILE] [-e ENZYMES_FILE] | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 11 FILES are the modifications/enzymes.xml of MaxQuant, located at | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 12 <ANACONDA_DIR>/pkgs/maxquant-<VERSION>/bin/conf/. | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 13 (for conda installations) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 14 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 15 Updates modification parameters in macros.xml. | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 16 """ | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 17 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 18 import argparse | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 19 import re | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 20 import xml.etree.ElementTree as ET | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 21 from xml.dom import minidom | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 22 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 23 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 24 def build_list(node, name, mod_list, append=False): | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 25 """Build the modifications list in macros.xml""" | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 26 node.clear() | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 27 node.tag = 'xml' | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 28 node.set('name', name) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 29 for m in mod_list: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 30 ET.SubElement(node, 'expand', attrib={'macro': 'mod_option', | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 31 'value': m}) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 32 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 33 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 34 parser = argparse.ArgumentParser() | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 35 parser.add_argument("-m", "--modifications", | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 36 help="modifications.xml of maxquant") | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 37 parser.add_argument("-e", "--enzymes", | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 38 help="enzymes.xml of maxquant") | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 39 args = parser.parse_args() | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 40 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 41 if args.modifications: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 42 mods_root = ET.parse(args.modifications).getroot() | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 43 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 44 mods = mods_root.findall('modification') | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 45 standard_mods = [] | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 46 label_mods = [] | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 47 for m in mods: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 48 if (m.findtext('type') == 'Standard' | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 49 or m.findtext('type') == 'AaSubstitution'): | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 50 standard_mods.append(m.get('title')) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 51 elif m.findtext('type') == 'Label': | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 52 label_mods.append(m.get('title')) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 53 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 54 if args.enzymes: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 55 enzymes_root = ET.parse(args.enzymes).getroot() | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 56 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 57 enzymes = enzymes_root.findall('enzyme') | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 58 enzymes_list = [e.get('title') for e in enzymes] | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 59 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 60 macros_root = ET.parse('./macros.xml').getroot() | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 61 for child in macros_root: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 62 if child.get('name') == 'modification' and args.modifications: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 63 build_list(child, 'modification', standard_mods) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 64 elif child.get('name') == 'label' and args.modifications: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 65 build_list(child, 'label', label_mods) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 66 elif child.get('name') == 'proteases' and args.enzymes: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 67 build_list(child, 'proteases', enzymes_list) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 68 | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 69 rough_string = ET.tostring(macros_root, 'utf-8') | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 70 reparsed = minidom.parseString(rough_string) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 71 pretty = reparsed.toprettyxml(indent=" ") | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 72 even_prettier = re.sub(r"\n\s+\n", r"\n", pretty) | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 73 with open('./macros.xml', 'w') as f: | 
| 
a52165553917
planemo upload for repository https://github.com/galaxyproteomics/tools-galaxyp/tree/master/tools/maxquant commit ab4e4f1817080cbe8a031a82cb180610ff140847
 galaxyp parents: diff
changeset | 74 print(even_prettier, file=f) | 
