Skip to main content

Forget about working directory errors

Project description

Usage guide

Are you fed up with that annoying FileNotFoundError when your working directory turns out to be something different from what you expected? Or, maybe, you are looking for an easy and robust way of declaring paths to configs and any data files in your project? Yeah, that drives us all crazy.

The package is really tiny, there are two function:

  • from_root helps with declaring absolute paths relative to your project root
  • from_here comes in handy when you want to declare a path relative to the current file

They are dead simple to use.

Let's assume we have a project with the next structure:

├── .git  # OPTIONAL. See explanation below
├── .project-root  # OPTIONAL. See explanation below
├── config.json  
├── assets  
│ ├── animation.gif  
│ └── logo.png  
└── package  
    ├── __init__.py
    ├── data.csv    
    ├── script.py
    ├── FROM_HERE_DEMO.py
    └── inner_package  
      ├── FROM_ROOT_DEMO.py  
      ├── __init__.py
      └── insanely
          └── deep
              └── dir
                  └── file.txt

from_root examples:

# <PROJECT_ROOT>/package/inner_package/FROM_ROOT_DEMO.py
from from_root import from_root

CONFIG_PATH = from_root('config.json')

PACKAGE_DATA_PATH = from_root('package', 'data.csv')

# `from_root` returns pathlib.Path object
# so we can take advantage of its fantastic "/" syntax
ASSETS_DIR = from_root('assets')
ANIMATION_PATH = ASSETS_DIR / 'animation.gif'
LOGO_PATH = ASSETS_DIR / 'logo.png'

# no matter how deep it's located
FILE_TXT_PATH = from_root('package', 'inner_package', 'insanely', 'deep', 'dir', 'file.txt')

# If `mkdirs` is set to True (False by default), all *args will be treated as dir names 
# and created for you. 
# If a directory already exists, nothing happens.

import pickle

RESULTS_DIR = from_root('package', 'deep', 'results', 'dir', mkdirs=True)
results = {
    'ones': [1, 1, 1],
    'zeros': [2, 2, 2]
}
for name, data in results.items():
    path = RESULTS_DIR / f'{name}.pkl'
    # `FileNotFoundError` is not raised because `from_root` has created all non-existing directories
    with path.open('wb') as file:
        pickle.dump(data, file)

# WARNING: don't do this, you'll end up with data.json directory:
with from_root('results', 'data.json', mkdirs=True).open('w') as file:
    ...

# Do this instead:
with (from_root('results', mkdirs=True) / 'data.json').open('w') as file:
    ...

from_here examples:

# <PROJECT_ROOT>/package/FROM_HERE_DEMO.py
from from_root import from_here

# The only difference from `from_root` is that `from_here` allows you to declare relative paths
# I think the examples speak for themselves quite good. 
# Take a look at tree above and compare with `from_root` examples

CONFIG_PATH = from_here('data.csv')
FILE_TXT_PATH = from_here('inner_package', 'insanely', 'deep', 'dir', 'file.txt')

How does it work?

When from_root is called, folders in the current traceback are looked through one by one in order to find .git directory or .project-root file (might be empty; you have to create it on your own). The first one that contains at least one of them are considered as a root directory.

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

from_root-1.3.0.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

from_root-1.3.0-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file from_root-1.3.0.tar.gz.

File metadata

  • Download URL: from_root-1.3.0.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.10.9 Darwin/20.6.0

File hashes

Hashes for from_root-1.3.0.tar.gz
Algorithm Hash digest
SHA256 da1359f5faabca367f685cac927cb2f307bb35c488fdd0361f963d6f1cd2674f
MD5 91477e3bb16b6ef61abbf67ee4f3131d
BLAKE2b-256 ae305259cfafc8372df008a5605ca19aba9d560285471ee043f39cbc5a7b7fa2

See more details on using hashes here.

File details

Details for the file from_root-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: from_root-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.10.9 Darwin/20.6.0

File hashes

Hashes for from_root-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7446a9b6481e668329cc11ad0a234fe4c83c63468c652e037d02846a75c726f8
MD5 a7da311bb5b8ab00de7f259014ccff6e
BLAKE2b-256 33a8451d0294d5d9ead3d26c25837df0588d1bcdd9235abf91e0ded629369921

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