Extended Pathlib
Project description
Superpathlib
Superpathlib offers Path objects with functionality extended from pathlib to maximize your productivity with a minimal amount of code.
Usage
from plib import Path
path = Path(filename)
1) Use properties to read & write path content in different formats
- text
- byte_content
- lines
- yaml
- json
- numpy
examples:
path.json = {key: value}
for line in path.lines:
if interesting(line):
process(line)
2) Use instance properties to get/set file metadata:
- get:
- size: filesize
- is_root: whether the owner of the file is a root user
- has_children: whether a path has children
- number_of_children: number of children in a folder
- filetype: content type of a file
- get & set:
- mtime: modified time
- tag: can be used for alternative ordering or metadata
examples:
path_new.mtime = path_old.mtime
if path.tag != skip_keyword and path.filetype == "video":
process(path)
3) Use class properties to access commonly used folders:
- docs
- assets
- ..
example:
names_path = Path.assets / 'names'
names = names_path.lines
4) Use additional functionality
- find(): recursively find all paths under a root that match a condition (extra options available for performance optimization)
- rmtree(): remove directory recursively
- copy_to(dest): copy content to dest
- copy_properties_to(dest): recursively copy path properties (mtime, tag) to all n-level children of dest
- tempfile(): create temporary file that can be used as context manager
- unpack(): extract archive(zip, tar, ..) file to desired folder
- pop_parent(): remove first parent from path in filesystem
examples:
with Path.tempfile() as tmp:
do_work(logfile=tmp)
log = tmp.text
process(log)
condition = lambda p: (p / '.git').exists()
for git_path in root.find(condition):
process_git(git_path)
5) Enhance existing functionality
- Automatically create parents when writing files, creating new files, renaming files, ..
- Return default values when path does not exist (e.g. size = 0, lines=[])
6) Inherit from Path to define your own additional functionality:
example:
from plib import Path as BasePath
class Path(BasePath):
def count_children(self):
return sum(1 for _ in self.iterdir())
This only works if you inherit from plib and not from the builtin pathlib
Installation
pip install superpathlib
Install the packages corresponding with the properties you want to use
- e.g. PyYaml for yaml property
- Packages listed in requirements.txt
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
superpathlib-1.0.2.tar.gz
(10.9 kB
view details)
Built Distribution
File details
Details for the file superpathlib-1.0.2.tar.gz
.
File metadata
- Download URL: superpathlib-1.0.2.tar.gz
- Upload date:
- Size: 10.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5642a097b43483bcd122e33a5b655a5676ee4a2fdb2c1e707f7860b45c3cd3ba |
|
MD5 | 8557695f8890d15f44c5252676f7eec8 |
|
BLAKE2b-256 | f9da338f44e03a2128901ddbc64cb54e5d5fe2fac8878b17cefaa9bc16104679 |
File details
Details for the file superpathlib-1.0.2-py3-none-any.whl
.
File metadata
- Download URL: superpathlib-1.0.2-py3-none-any.whl
- Upload date:
- Size: 8.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c2272d162dd4ce29410569caeb104141e55c3d29c02637e4e732afa31e5364a |
|
MD5 | 54611e867f549b18928848a61e78b30a |
|
BLAKE2b-256 | ae44181d54835134194c4df8693751bd5b3db7fdbe64354b39ad306d16b87df6 |