tempfile.TemporaryDirectory context manager in Python 2.7 tempfile.TemporaryDirectory context manager in Python 2.7 python python

tempfile.TemporaryDirectory context manager in Python 2.7


Another option is the "backports.tempfile" package on pypi: https://pypi.python.org/pypi/backports.tempfile

Quoting the project's description: "This package provides backports of new features in Python’s tempfile module under the backports namespace."

Install with:

pip install backports.tempfile

Then use it in your script:

from backports import tempfilewith tempfile.TemporaryDirectory() as temp_dir:    # modify files in this dir# here the temporary directory does not exist any more.


tempfile.TemporaryDirectory() was added to the tempfile standard library in Python 3.2

It's a simple wrapper for tempfile.mkdtemp. It is coded in pure Python and can be easily ported to Python 2.7.

For example:

from __future__ import print_functionimport warnings as _warningsimport os as _osfrom tempfile import mkdtempclass TemporaryDirectory(object):    """Create and return a temporary directory.  This has the same    behavior as mkdtemp but can be used as a context manager.  For    example:        with TemporaryDirectory() as tmpdir:            ...    Upon exiting the context, the directory and everything contained    in it are removed.    """    def __init__(self, suffix="", prefix="tmp", dir=None):        self._closed = False        self.name = None # Handle mkdtemp raising an exception        self.name = mkdtemp(suffix, prefix, dir)    def __repr__(self):        return "<{} {!r}>".format(self.__class__.__name__, self.name)    def __enter__(self):        return self.name    def cleanup(self, _warn=False):        if self.name and not self._closed:            try:                self._rmtree(self.name)            except (TypeError, AttributeError) as ex:                # Issue #10188: Emit a warning on stderr                # if the directory could not be cleaned                # up due to missing globals                if "None" not in str(ex):                    raise                print("ERROR: {!r} while cleaning up {!r}".format(ex, self,),                      file=_sys.stderr)                return            self._closed = True            if _warn:                self._warn("Implicitly cleaning up {!r}".format(self),                           ResourceWarning)    def __exit__(self, exc, value, tb):        self.cleanup()    def __del__(self):        # Issue a ResourceWarning if implicit cleanup needed        self.cleanup(_warn=True)    # XXX (ncoghlan): The following code attempts to make    # this class tolerant of the module nulling out process    # that happens during CPython interpreter shutdown    # Alas, it doesn't actually manage it. See issue #10188    _listdir = staticmethod(_os.listdir)    _path_join = staticmethod(_os.path.join)    _isdir = staticmethod(_os.path.isdir)    _islink = staticmethod(_os.path.islink)    _remove = staticmethod(_os.remove)    _rmdir = staticmethod(_os.rmdir)    _warn = _warnings.warn    def _rmtree(self, path):        # Essentially a stripped down version of shutil.rmtree.  We can't        # use globals because they may be None'ed out at shutdown.        for name in self._listdir(path):            fullname = self._path_join(path, name)            try:                isdir = self._isdir(fullname) and not self._islink(fullname)            except OSError:                isdir = False            if isdir:                self._rmtree(fullname)            else:                try:                    self._remove(fullname)                except OSError:                    pass        try:            self._rmdir(path)        except OSError:            passimport oswith TemporaryDirectory() as tmp_dir:    print("Temporary directory path: %s" % tmp_dir)    print(os.path.isdir(tmp_dir))# here the temporary diretory does not exist any more.print(os.path.isdir(tmp_dir))