sitecustomize._vendor.zipp
Module Contents
Classes
A pathlib-compatible interface for zip files. |
- class sitecustomize._vendor.zipp.Path(root, at='')
A pathlib-compatible interface for zip files.
Consider a zip file with this structure:
. ├── a.txt └── b ├── c.txt └── d └── e.txt>>> data = io.BytesIO() >>> zf = zipfile.ZipFile(data, 'w') >>> zf.writestr('a.txt', 'content of a') >>> zf.writestr('b/c.txt', 'content of c') >>> zf.writestr('b/d/e.txt', 'content of e') >>> zf.filename = 'mem/abcde.zip'
Path accepts the zipfile object itself or a filename
>>> root = Path(zf)
From there, several path operations are available.
Directory iteration (including the zip file itself):
>>> a, b = root.iterdir() >>> a Path('mem/abcde.zip', 'a.txt') >>> b Path('mem/abcde.zip', 'b/')
name property:
>>> b.name 'b'
join with divide operator:
>>> c = b / 'c.txt' >>> c Path('mem/abcde.zip', 'b/c.txt') >>> c.name 'c.txt'
Read text:
>>> c.read_text() 'content of c'
existence:
>>> c.exists() True >>> (b / 'missing.txt').exists() False
Coercion to string:
>>> import os >>> str(c).replace(os.sep, posixpath.sep) 'mem/abcde.zip/b/c.txt'
At the root,
name,filename, andparentresolve to the zipfile. Note these attributes are not valid and will raise aValueErrorif the zipfile has no filename.>>> root.name 'abcde.zip' >>> str(root.filename).replace(os.sep, posixpath.sep) 'mem/abcde.zip' >>> str(root.parent) 'mem'
- property name
- property suffix
- property suffixes
- property stem
- property filename
- property parent
- __repr = '{self.__class__.__name__}({self.root.filename!r}, {self.at!r})'
- __truediv__
- open(mode='r', *args, pwd=None, **kwargs)
Open this entry as text or binary following the semantics of
pathlib.Path.open()by passing arguments through to io.TextIOWrapper().
- read_text(*args, **kwargs)
- read_bytes()
- _is_child(path)
- _next(at)
- is_dir()
- is_file()
- exists()
- iterdir()
- __str__()
Return str(self).
- __repr__()
Return repr(self).
- joinpath(*other)