Skip to main content

mzml2isa - mzML to ISA-tab parsing tool

Project description

Version Py versions Git Build Status License

Overview

mzml2isa is a Python3 program that can be used to generate an ISA-Tab structure out of mzML files, providing the backbone of a study which can then be edited with an ISA editing tool (see MetaboLights pre-packaged ISA Creator)

Currently the program does the following * Extract meta information from mzML files and store as either python dictionary or JSON format * Create an ISA-Tab file structure with relevant meta information * Add additional metadatas that cannot be parsed from mzML files to the ISA-Tab files through a JSON formatted dictionnary.

Install

With PIP

If pip is installed, it can be used to easily install the parser (this may need to be run as administrator depending on the machine’s architecture):

pip3 install mzml2isa

Without PIP

Alternatively, you can also clone the repository and install from the source :

git clone git://github.com/althonos/mzml2isa && cd mzml2isa
python3 setup.py install

mzml2isa has 2 optional dependencies: progressbar2 and lxml, the latter quickening the parsing process while the other enhances the output of the program. To install them both, use pip:

pip3 install lxml progressbar2

Use

CLI

The parser comes with a simple one-liner:

mzml2isa -i /path/to/mzml_files/ -o /path/to/out_folder/ -s name_of_study

Module

It is also possible to import the package:

from mzml2isa import parsing

in_dir = "/path/to/mzml_files/"
out_dir = "/path/to/out_folder/"
study_identifier_name = "name_of_study"

parsing.full_parse(in_dir, out_dir, study_identifier_name)

Meta extraction

If you just want to extract meta information:

from mzml2isa import mzml

onefile = os.path.join(in_dir,"samp1.mzML")
mm = mzml.mzMLmeta(onefile)

# python dictionary format
print mm.meta

# JSON format
print mm.meta_json

Metabolights

To download some real data from MetaboLights studies to test the converter with, run

python scripts/metabolights-dl.py <size>

from inside the repository, where size is the maximum size in GiB you can allocate to download files. The script will download the files to the example_files/metabolights folder and then run mzml2isa on those files..

If you use a *NIX machine with curlftpfs and bash available, you can also run

scripts/metabolights.sh

to mount the database to the example directory and start converting mzML studies.

Workflow

workflow

Ref

A modified version of the ontology extraction from this blog[1]_ was used, and a slightly modified class from pymzml[2]_

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mzml2isa-0.4.14.tar.gz (124.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mzml2isa-0.4.14-py3-none-any.whl (142.9 kB view details)

Uploaded Python 3

File details

Details for the file mzml2isa-0.4.14.tar.gz.

File metadata

  • Download URL: mzml2isa-0.4.14.tar.gz
  • Upload date:
  • Size: 124.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for mzml2isa-0.4.14.tar.gz
Algorithm Hash digest
SHA256 575c49024633a5f97e1dffa52933bbe29549c659579d18488264ac9b5d63524d
MD5 25138b2ab5c855ec00e8523605cdee87
BLAKE2b-256 64a44407f34205398fc76ae5f2e1b7edc21147447965ab522e8792ab54e28730

See more details on using hashes here.

File details

Details for the file mzml2isa-0.4.14-py3-none-any.whl.

File metadata

File hashes

Hashes for mzml2isa-0.4.14-py3-none-any.whl
Algorithm Hash digest
SHA256 b15ba9cd6da8b8b072d41de96c147845aa9f7049787fa8e092d094df4c8cac1c
MD5 f45f48b17604f10422bb1ec45a65f737
BLAKE2b-256 6a279e00f7b89e1d6d5c08eb8d531f9f037d646573615b6eb278e66869243a3b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page