Source code for pybedtools

import os
import sys
import subprocess
import tempfile
import logging
import copyreg

from .cbedtools import (
    Interval,
    IntervalFile,
    overlap,
    Attributes,
    MalformedBedLineError,
    IntervalIterator,
)
from . import contrib
from .helpers import (
    get_tempdir,
    set_tempdir,
    cleanup,
    find_tagged,
    set_bedtools_path,
    chromsizes,
    get_chromsizes_from_ucsc,
    chromsizes_to_file,
    create_interval_from_list,
)
from . import helpers
from .bedtool import BedTool
from . import genome_registry
from . import stats
from .version import __version__
from .filenames import data_dir, example_filename, list_example_files
from .bedtool import example_bedtool

from . import settings
from .logger import logger, ch

example_files = ["a.bed.", "b.bed", "test.fa", "a.bam"]


[docs] def debug_mode(x): """ Enable debug mode. Use debug_mode(True) to show debug log events in the console and to save calling info in BedTool objects, and turn it off again with debug_mode(False). Note that `pybedtools.KEEP_TEMPFILES` will be set as well, so you will need to clean up the tempfile directory manually after using debug mode. """ if x: logger.setLevel(logging.DEBUG) ch.setLevel(logging.DEBUG) _DEBUG = True KEEP_TEMPFILES = True logger.info( "Debug mode enabled. You may also want to set " "pybedtools.KEEP_TEMPFILES=True to prevent automatic deletion " "of files upon exit." ) else: logger.setLevel(logging.INFO) ch.setLevel(logging.INFO) _DEBUG = False KEEP_TEMPFILES = False logger.info("Debug mode disabled")
def check_for_bedtools(*args, **kwargs): """ For backwards compatibility; please use helpers._check_for_bedtools() """ return helpers._check_for_bedtools(*args, **kwargs) # Allow Interval objects to be pickled -- required if you want to pass them # across process boundaries def interval_constructor(fields): return create_interval_from_list(list(fields)) def interval_reducer(interval): return interval_constructor, (tuple(interval.fields),) copyreg.pickle(Interval, interval_reducer, interval_constructor) def load_path_config(fn): """ You can use a config file to specify installation paths of various programs used by pybedtools. This can be useful for testing, or using different versions of programs. `fn` is a config file with the following format. If an entry is blank, then assume it's already on the path. All items must be lowercase:: [paths] bedtools=/tools/BEDTools/bin r= tabix= bgzip= You only need to specify paths you need to change, so this is a valid file that will only specify the path to use for R:: [paths] r=/usr/bin/R-dev If `fn` is not a string, then assume it is a dictionary of (program, paths). This is used primarily for testing. """ setters = dict( bedtools=helpers.set_bedtools_path, r=helpers.set_R_path, tabix=helpers.set_tabix_path, bgzip=helpers.set_bgzip_path, ) if isinstance(fn, dict): for prog, setter in list(setters.items()): try: path = fn[prog] setter(path) except KeyError: pass if isinstance(fn, str): import configparser c = configparser.SafeConfigParser() c.read(fn) if c.sections() != ["paths"]: raise ValueError( "Invalid path config -- must have " "only one section, [paths]." ) for prog, setter in list(setters.items()): try: path = c.get("paths", prog) setter(path) except configparser.NoOptionError: pass