Skip to main content

Python utility for cleaner handling of paths

Project description

Introduction

This package standardizes the handling of paths in a Python project by allowing all paths to be relative to the project repo root. The package discovers the project root based on the location of a special (empty) .py-repo-root file. The project root indicator can be overriden with a custom one, if desired.

This package was heavily inspired by pyprojroot. This package allows custom root file indicators, avoids recursive "/" is parent of "/" issue and can use the current file location to start walking the directory tree.

Setup

Installation:

pip install py-repo-root

Usage

Get project root, using the default list of project root indicators

from pyreporoot import project_root

project_root_dir = project_root(__file__)

Specify a custom project root indicator (not included in the list above)

project_root_dir = project_root(__file__, root_files='.my-root-indicator')

Another common usage pattern may be to add the project_root to PYTHONPATH for the purposes of running some scripts.

import sys
from pyreporoot import project_root

sys.path.insert(0, project_root(__file__))

Getting a relative path from the project root for a file:

from pathlib import Path
from projectroot import project_root

project_root_dir = project_root(__file__)
path_rel_to_project_root = Path(project_root_dir).joinpath('/path/to/file.txt')

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

py-repo-root-2.0.0.tar.gz (3.6 kB view details)

Uploaded Source

Built Distribution

py_repo_root-2.0.0-py3-none-any.whl (4.0 kB view details)

Uploaded Python 3

File details

Details for the file py-repo-root-2.0.0.tar.gz.

File metadata

  • Download URL: py-repo-root-2.0.0.tar.gz
  • Upload date:
  • Size: 3.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.9.6

File hashes

Hashes for py-repo-root-2.0.0.tar.gz
Algorithm Hash digest
SHA256 1dc7a882355e2043256a49a2b9df400ce2d813869e2f095e2f895e1a48b6d085
MD5 5fa4f790404d254d16a339155b5739f6
BLAKE2b-256 d7b44821a73747703e3691a54e3d8cc6e640ca5d0b0779cc0feb79aa25f93aaf

See more details on using hashes here.

File details

Details for the file py_repo_root-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: py_repo_root-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 4.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.9.6

File hashes

Hashes for py_repo_root-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1c66034931ebda96ddef8eb5e96b28b3493442aa52ac0ece4e73242c616d9897
MD5 043b64003bf285c82fd97665a0a31791
BLAKE2b-256 306c411ab4369d4bb6c2aaebcb63e89875917e23517fd319d99923e31707e68c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page