一个统一的路径处理库,支持本地文件系统、HTTP 和 S3 存储的路径操作
Project description
Omni-Pathlib
Omni-Pathlib is a unified path handling library that supports path operations for local file systems, HTTP, and S3 storage. It provides both synchronous and asynchronous APIs, making it easy and consistent to operate files across different storage systems.
Installation
pip install omni-pathlib
Basic Usage
from omni_pathlib import OmniPath
# Create different types of paths
http_path = OmniPath("https://example.com/file.txt")
s3_path = OmniPath("s3://my-bucket/path/to/file.txt")
local_path = OmniPath("/local/path/to/file.txt")
# Read file content
content = http_path.read_text() # Read from HTTP
s3_content = s3_path.read_text() # Read from S3
local_content = local_path.read_text() # Read from local
# Asynchronous operations
async def main():
content = await http_path.async_read_text()
s3_content = await s3_path.async_read_text()
local_content = await local_path.async_read_text()
Features
- Unified path operation interface
- Supports local file systems, HTTP, and S3 storage
- Synchronous and asynchronous APIs
- HTTP supports caching and resuming downloads
- S3 supports complete bucket operations
- Local file system supports standard path operations
Function Interface Description
Basic Operations
All storage types support the following operations:
# Path attributes
path.name # Get the path name
path.stem # Get the path name without suffix
path.suffix # Get the path suffix
path.parent # Get the parent path
path.protocol # Get the protocol type ('file', 'http', 's3')
# Basic operations
path.exists() # Check if the path exists
path.iterdir() # Iterate through directory contents
path.stat() # Get file information (size, modification time, etc.)
path.read_bytes() # Read binary content
path.read_text() # Read text content
path.write_bytes(data) # Write binary content
path.write_text(data) # Write text content
path.delete() # Delete file
# All operations have corresponding asynchronous versions
await path.async_exists()
await path.async_iterdir()
# ... and so on
Local File System Specific Operations
mkdir(parents=False, exist_ok=False)/async_mkdir()- Create a directoryrmdir()/async_rmdir()- Remove an empty directoryrename(target)/async_rename(target)- Rename a file/directoryis_dir()/async_is_dir()- Check if it is a directoryis_file()/async_is_file()- Check if it is a file
HTTP Specific Features
- Supports resuming downloads
- Automatically caches downloaded content
- Does not support write and delete operations
S3 Specific Features
- Fully supports S3 bucket operations
- Supports custom endpoints
- Supports multiple authentication methods
- Supports specifying profile in URL scheme
S3 Profile Configuration Priority
Configuration priority from high to low:
- Configuration passed directly as parameters
- Profile specified in URL scheme (e.g.,
s3+my_profile://bucket/key) - Configuration through environment variable
AWS_PROFILE defaultprofile in configuration file- The first profile found in the configuration file
S3 URL Scheme Example
# Parameter priority is higher than URL scheme
path = OmniPath(
"s3+my_profile://bucket/key",
profile_name="other_profile" # Will use other_profile instead of my_profile
)
# Specify profile through URL scheme
path = OmniPath("s3+my_profile://bucket/key") # Will use my_profile configuration
# Specify profile through environment variable
os.environ["AWS_PROFILE"] = "other_profile"
path = OmniPath("s3://bucket/key") # Will use other_profile configuration
# Specify profile through configuration file
path = OmniPath("s3://bucket/key") # Will use default configuration (if exists) or the first found configuration
S3 Profiles Retrieval Logic
- Retrieve environment variable configurations from
AWS_ACCESS_KEY_ID,AWS_SECRET_ACCESS_KEY,AWS_REGION,OSS_ENDPOINT,S3_ENDPOINT,AWS_ENDPOINT_URL. These configurations will default to thedefaultprofile but can be specified to other named profiles by adding a prefix, e.g.,my_profile__AWS_ACCESS_KEY_ID=my_access_key_idwill go into the profile namedmy_profile. - Load configurations from the configuration file path obtained from the environment variable
AWS_SHARED_CREDENTIALS_FILE, defaulting to~/.aws/credentials.
Development
Install Dependencies
uv sync
Run Tests
uv run pytest
Commit
pre-commit install
cz commit
Release
cz bump
git push --follow-tags
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file omni_pathlib-0.3.7.tar.gz.
File metadata
- Download URL: omni_pathlib-0.3.7.tar.gz
- Upload date:
- Size: 132.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
55318995f1ae648da99598c847a5b1e27669004124195db8159e696fa53ae748
|
|
| MD5 |
a3d25e97efb5a1e1342b004160a76a4f
|
|
| BLAKE2b-256 |
28a17e51b09d90b07b06ac9f2a42e738f0c9ed9220ac0e2ac6bab80c1a18bcb1
|
Provenance
The following attestation bundles were made for omni_pathlib-0.3.7.tar.gz:
Publisher:
publish-to-pypi.yml on Haskely/omni-pathlib
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
omni_pathlib-0.3.7.tar.gz -
Subject digest:
55318995f1ae648da99598c847a5b1e27669004124195db8159e696fa53ae748 - Sigstore transparency entry: 175336517
- Sigstore integration time:
-
Permalink:
Haskely/omni-pathlib@0f50a8c3db10a7bb895f6fd627010c57b806ffca -
Branch / Tag:
refs/tags/v0.3.7 - Owner: https://github.com/Haskely
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@0f50a8c3db10a7bb895f6fd627010c57b806ffca -
Trigger Event:
push
-
Statement type:
File details
Details for the file omni_pathlib-0.3.7-py3-none-any.whl.
File metadata
- Download URL: omni_pathlib-0.3.7-py3-none-any.whl
- Upload date:
- Size: 26.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0873e8b1f9a5d92e843148487467e709b2a074e834ea065f6a2e595f67c110ea
|
|
| MD5 |
70a15a0622e320acc74f10c6278b2b2b
|
|
| BLAKE2b-256 |
73397f395e317dafa8c6f69513634e3c24bfac0797492fb1ed0c8d0beedf6dd5
|
Provenance
The following attestation bundles were made for omni_pathlib-0.3.7-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on Haskely/omni-pathlib
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
omni_pathlib-0.3.7-py3-none-any.whl -
Subject digest:
0873e8b1f9a5d92e843148487467e709b2a074e834ea065f6a2e595f67c110ea - Sigstore transparency entry: 175336519
- Sigstore integration time:
-
Permalink:
Haskely/omni-pathlib@0f50a8c3db10a7bb895f6fd627010c57b806ffca -
Branch / Tag:
refs/tags/v0.3.7 - Owner: https://github.com/Haskely
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@0f50a8c3db10a7bb895f6fd627010c57b806ffca -
Trigger Event:
push
-
Statement type: