Skip to main content

Environment and .env file reader

Reason this release was yanked:

typo in release

Project description

defaultenv

Environment and config file reader for python3. Warrning: slightly magic inside. This module magically read and use environment value both from '.env' file and environment itself.

Since version 0.0.6 .env file will be rereaded on the fly on next env call, so now your environment is always up to date.

$ echo "MY_VAL='test'" > .env
$ python
>>> from defaultenv import env
>>> env('PATH')
'/usr/local/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/X11/bin'
>>> env('TEST')
>>> env('MY_VAL')
'test'
>>> import os; os.environ['MY_VAL']
'test'

env method may be used to check the value of variable. If variable is not defined env method will return None. If both environment variable and corresponding .env record is exist then .env have a priority. And yes, you can use os.environ instead of env(), all records from .env will be exported immidiately.

For additional convinience you can use env() with default argument, for example:

>>> from defaultenv import env
>>> env('TEST', 'no test')
'no test'
>>> env('UID')
'1000'
>>> env('UID', int)
1000
>>> env('HOME', pathlib.Path)
PosixPath("/home/bobuk")
>>> env('PATH', lambda x: [pathlib.Path(_) for _ in x.split(':')])
[PosixPath('/usr/local/sbin'), PosixPath('/usr/local/bin'), PosixPath('/usr/sbin'), PosixPath('/usr/bin'),
 PosixPath('/sbin'), PosixPath('/bin')]

If default argument for env() is not empty, and key what you looking for is not exists env() will return you value of default. But if default is callable (like object, lambda or function) then instead value of key from environment will be passed to this callable. My favorite is to send just int because it's the easiest way to convert your default to integer.

Since version 0.0.2 for more convinience two classes (ENV and ENVC) was added. You can use your environment variable name without method calling.

$ python
>>> from defaultenv import ENV
>>> ENV.PATH
'/usr/local/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/X11/bin'

ENV usage removing unnesesery typing of perenthesis and quotes. In this example i've save 4 keystrokes for you. But it's not very convinient to type uppercased name everytime. Let's imagine what my pinky finger is killing me.

$ python
>>> from defaultenv import ENVC as env
>>> env.shell
'/usr/local/bin/zsh'
>>> env.home
'/home/bobuk'

As you can see ENVC convert your variable name to uppercase. For both ENVC and ENV there's a method defaults to add default values of callables (as for env above).

>>> from defaultenv import ENVC as env
>>> env.defaults(test = 1, path = lambda x: x.split(':'), pid=int)
>>> env.test
1
>>> env.path
['/usr/local/sbin', '/usr/local/bin', '/usr/sbin', '/usr/bin', '/sbin', '/bin']

What the difference between os.environ.get('PATH', None) and env.path? It's easy to calculate and the result is 21 (which is half of 42).

Since version 0.0.9 you can use even more authomated ENVCD which is ENVC but with predefined defaults. Every path (or colon-separated paths list) will be defaulted to PosixPath, every digital value converted to int.

>>> from defaultenv import ENVCD as env
>>> env.path
[PosixPath('/usr/local/bin'), PosixPath('/usr/local/bin'), PosixPath('/usr/bin'), PosixPath('/bin'), PosixPath('/usr/sbin')]

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

defaultenv-0.0.13.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

defaultenv-0.0.13-py3-none-any.whl (4.4 kB view details)

Uploaded Python 3

File details

Details for the file defaultenv-0.0.13.tar.gz.

File metadata

  • Download URL: defaultenv-0.0.13.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.5 CPython/3.8.3 Darwin/19.5.0

File hashes

Hashes for defaultenv-0.0.13.tar.gz
Algorithm Hash digest
SHA256 00758c1e7bf07de5221dc161b1e486a81726bdc04406d437c25e59fcce2bb107
MD5 27847eb87a7b1002d3859dd106e3a7ff
BLAKE2b-256 2d689c55720ed21c95aea8ad7084a93cae00861bd39f315e8815a53418118b2c

See more details on using hashes here.

File details

Details for the file defaultenv-0.0.13-py3-none-any.whl.

File metadata

  • Download URL: defaultenv-0.0.13-py3-none-any.whl
  • Upload date:
  • Size: 4.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.5 CPython/3.8.3 Darwin/19.5.0

File hashes

Hashes for defaultenv-0.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 4a2ee1be1cbb768219a01aca8470ddce28bc02b2440d9d7df383d206e9cbebb4
MD5 ecfa29aba3c194f28afc45e692b0f349
BLAKE2b-256 c90a6edc5bc94e9c905727adfd28bb135fbbdcbe0f9873b5434ba7453f738c42

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