Hard-coding configuration is bad. This is one of the things that newbie programmers learn quickly after they realize that have committed sensitive information to a public GitHub repository. And it happens so easily. Often, you are in the spur of the moment, wanting to test something locally, when you figure out that you need some API key in order for your app to work. Adding the key to the code takes a second, and is just as easy to forget when committing. The Twelve-Factor-App methodology calls this a violation, and has whole section on why should be externalized and read from the environment at runtime.
I used to avoid using environment variables, because they made it hard to set up a local environment for testing. I’d either pass all the assignments at the start, or use a cumbersome startup script to export them to the current shell.
Luckily, it is easy to improve the quality of your code, and ease testing in different environments at the same time. It has become somewhat of a standard practice to use .env
(a.k.a dotenv) files for configuring sensitive data while testing across environments. A dotenv file contains nothing more than text, where it has one environment variable assignment per line:
ABC_KEY=1234xyz
DEF_KEY=2349875
DEBUG=True
NOTE: Dotenv files must be ignored from version control for exactly the same reason mentioned at the beginning of this post: exposing sensitive information as part of the project is bad. These files are only used to quickly set up or change an environment when needed.
Using a dotenv file in our app #
How do we get our Python app to read a .env
file? python-dotenv is a great Python package that does exactly that. It will search for a .env
as part of the project, and if it finds one, will expose the variables in it to the app. All you need to do, is pip install python-dotenv
and add the following couple of lines at the start of your project:
from dotenv import load_dotenv
load_dotenv()
The starting point may vary, depending on whether your project is a command line script, a Flask, or a Django project. For instance, in a Django project, the above two lines need to be added at the top of the settings.py
file.
Having set python-loadenv
up, the rest is easy. Create a .env
file at the root of your app with all the environment variables needed to configure it, and make sure that you invoke them properly from your code (e.g. use something like os.getenv('MY_API_KEY')
). Don’t forget to exclude the .env
file from being checked into your source code repository!
Links #
Have something to say? Join the discussion below 👇
Want to explore instead? Fly with the time capsule 🛸
You may also find these interesting
Live-reloading of Python Modules in the Python REPL / IPython / Jupyter Console
As modules get bigger, they tend to import other modules, or do some preliminary setup work. Python 3 supports inline reloading of modules.
Any Code Style You Like, So Long As It’s Black
Write clear and consistently indented Python code with zero effort.
Epic Rap Battles of Programming: Python vs. OCaml
Two programming language giants appear on stage for a massive rap battle. Who will win?
Python is Easy. Go is Simple. Simple != Easy.
Python and Go have distinct qualities that can complement each other.