scriptExit 1 с pybedtools venn_mpl - snakemake 5.2.4 - PullRequest
3 голосов
/ 24 мая 2019

Я хочу создать VennDiagramms с pybedtools. Существует специальный скрипт, использующий matplotlib, который называется venn_mpl. Он отлично работает, когда я опробую его в своем блокноте Jupyter. Вы можете сделать это с помощью Python или с помощью команд оболочки.

К сожалению, что-то пошло не так, когда я хочу использовать это в своем файле змеи, и я не могу понять, в чем проблема.

Прежде всего, это скрипт: venn_mpl.py

#!/gnu/store/3w3nz0h93h7jif9d9c3hdfyimgkpx1a4-python-wrapper-3.7.0/bin/python
"""
Given 3 files, creates a 3-way Venn diagram of intersections using matplotlib; \
see :mod:`pybedtools.contrib.venn_maker` for more flexibility.

Numbers are placed on the diagram.  If you don't have matplotlib installed.
try venn_gchart.py to use the Google Chart API instead.

The values in the diagram assume:

    * unstranded intersections
    * no features that are nested inside larger features
"""

import argparse
import sys
import os
import pybedtools

def venn_mpl(a, b, c, colors=None, outfn='out.png', labels=None):
    """
    *a*, *b*, and *c* are filenames to BED-like files.

    *colors* is a list of matplotlib colors for the Venn diagram circles.

    *outfn* is the resulting output file.  This is passed directly to
    fig.savefig(), so you can supply extensions of .png, .pdf, or whatever your
    matplotlib installation supports.

    *labels* is a list of labels to use for each of the files; by default the
    labels are ['a','b','c']
    """
    try:
        import matplotlib.pyplot as plt
        from matplotlib.patches import Circle
    except ImportError:
        sys.stderr.write('matplotlib is required to make a Venn diagram with %s\n' % os.path.basename(sys.argv[0]))
        sys.exit(1)

    a = pybedtools.BedTool(a)
    b = pybedtools.BedTool(b)
    c = pybedtools.BedTool(c)

    if colors is None:
        colors = ['r','b','g']

    radius = 6.0
    center = 0.0
    offset = radius / 2

    if labels is None:
        labels = ['a','b','c']

Тогда мой код:

rule venndiagramm_data:
     input:
         data = expand("bed_files/{sample}_peaks.narrowPeak", sample=config["samples"]["data"])
     output:
         "figures/Venn_PR1_PR2_GUI_data.png"
     run:
         col = ['g','k','b']
         lab = ['PR1_data','PR2_data','GUI_data']
         venn_mpl(input.data[0], input.data[1], input.data[2], colors = col, labels = lab, outfn = output)

Ошибка:

SystemExit in line 62 of snakemake_generatingVennDiagramm.py:
1

Змейка-лог дает мне только:

rule venndiagramm_data:
    input: bed_files/A_peaks.narrowPeak,bed_files/B_peaks.narrowPeak, bed_files/C_peaks.narrowPeak
    output: figures/Venn_PR1_PR2_GUI_data.png
    jobid: 2

Shutting down, this might take some time.
Exiting because a job execution failed. Look above for error message

Я уже пытался добавить как написано в документации:

rule error:
  shell:
    """
    set +e
    somecommand ...
    exitcode=$?
    if [ $exitcode -eq 1 ]
    then
        exit 1
    else
        exit 0
    fi
    """

но это ничего не изменило.

Тогда моей следующей идеей было просто сделать это, используя команду оболочки, которую я также тестировал ранее и которая работала отлично. Но потом я получил другое, но, похоже, довольно похожее сообщение об ошибке, для которого я тоже не нашел правильного решения:

rule venndiagramm_data_shell:
    input:
        data = expand("bed_files/{sample}_peaks.narrowPeak", sample=config["samples"]["data"])
    output:
        "figures/Venn_PR1_PR2_GUI_data.png"
    shell:
        "venn_mpl.py -a {input.data[0]} -b {input.data[1]} -c {input.data[2]} --color 'g,k,b' --labels 'PR1_data,PR2_data,GUI_data'"
The snakemake log:

[Thu May 23 16:37:27 2019]
rule venndiagramm_data_shell:
    input: bed_files/A_peaks.narrowPeak, bed_files/B_peaks.narrowPeak, bed_files/C_peaks.narrowPeak
    output: figures/Venn_PR1_PR2_GUI_data.png
    jobid: 1

[Thu May 23 16:37:29 2019]
Error in rule venndiagramm_data_shell:
    jobid: 1
    output: figures/Venn_PR1_PR2_GUI_data.png

RuleException:
CalledProcessError in line 45 of snakemake_generatingVennDiagramm.py:
Command ' set -euo pipefail;  venn_mpl.py -a input.data[0] -b input.data[1] -c input.data[2] --color 'g,k,b' --labels 'PR1_data,PR2_data,GUI_data' ' returned non-zero exit status 1.

Кто-нибудь имеет представление, что может быть причиной этого и как это исправить?

К вашему сведению: я сказал, что проверил это, не запуская его с помощью змеиного мейкера. Это мой рабочий код:

from snakemake.io import expand
import yaml
import pybedtools
from pybedtools.scripts.venn_mpl import venn_mpl

config_text_real = """ 
samples:
    data:
    - A
    - B
    - C
    control:
    - A_input 
    - B_input
    - C_input
"""
config_vennDiagramm = yaml.load(config_text_real)
config = config_vennDiagramm

data = expand("{sample}_peaks.narrowPeak", sample=config["samples"]["data"])
col = ['g','k','b']
lab = ['PR1_data','PR2_data','GUI_data']
venn_mpl(data[0], data[1], data[2], colors = col, labels = lab, outfn = 'Venn_PR1_PR2_GUI_data.png')

control = expand("{sample}_peaks.narrowPeak", sample=config["samples"]["control"])
lab = ['PR1_control','PR2_control','GUI_control']
venn_mpl(control[0], control[1], control[2], colors = col, labels = lab, outfn = 'Venn_PR1_PR2_GUI_control.png')

и внутри моего ноутбука Jupyter для оболочки:

!A='../path/to/file/A_peaks.narrowPeak'
!B='../path/to/file/B_peaks.narrowPeak'
!C='../path/to/file/C_peaks.narrowPeak'
!col=g,k,b
!lab='PR1_data, PR2_data, GUI_data'
!venn_mpl.py -a ../path/to/file/A_peaks.narrowPeak -b ../path/to/file/B_peaks.narrowPeak -c ../path/to/file/C_peaks.narrowPeak --color "g,k,b" --labels "PR1_data, PR2_data, GUI_data"

Причина, по которой я использовал полный путь вместо переменной, заключается в том, что по какой-то причине код не работал с вызовом переменной с "$ A".

1 Ответ

2 голосов
/ 25 мая 2019

Не уверен, что это исправит, но я замечаю одну вещь:

shell:
    "venn_mpl.py -a input.data[0] -b input.data[1] -c input.data[2]..." 

, вероятно, должно быть:

shell:
    "venn_mpl.py -a {input.data[0]} -b {input.data[1]} -c {input.data[2]}..." 
...