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.4.tar.gz
(10.9 kB
view details)
Built Distribution
File details
Details for the file superpathlib-1.0.4.tar.gz
.
File metadata
- Download URL: superpathlib-1.0.4.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 | 4f58ec8bfe4734f98e180abc49ce602cd8ade8bde17b9b4a26184f8ecd3effab |
|
MD5 | bb7c3e496702a16a3c5793b29d57f549 |
|
BLAKE2b-256 | 301b6867d8eecabbae547eea1948b85f2df05c4e3c8ca0d77a76182f0b9cc1bd |
File details
Details for the file superpathlib-1.0.4-py3-none-any.whl
.
File metadata
- Download URL: superpathlib-1.0.4-py3-none-any.whl
- Upload date:
- Size: 9.0 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 | ce8902a1926f639aa99cafffca8a81f59c820ae4efa52207dd639c36a218c048 |
|
MD5 | 6ae08d5156f5ef33eda6a93e1b7e6fc2 |
|
BLAKE2b-256 | ba0413b46e153a7dc8b96f211e87244756df9ed8c234f7ad918cddf7a68acbcd |