Skip to content

Project Layout โ€‹

Create a project directory and enter it:

shell
$ mkdir flask-tutorial
$ cd flask-tutorial
$ mkdir flask-tutorial
$ cd flask-tutorial

Then follow the installation instructions to set up a Python virtual environment and install Flask for your project.

The tutorial will assume youโ€™re working from the flask-tutorial directory from now on. The file names at the top of each code block are relative to this directory.

A Flask application can be as simple as a single file.

python
# hello.py
from flask import Flask

app = Flask(__name__)


@app.route('/')
def hello():
    return 'Hello, World!'
# hello.py
from flask import Flask

app = Flask(__name__)


@app.route('/')
def hello():
    return 'Hello, World!'

However, as a project gets bigger, it becomes overwhelming to keep all the code in one file. Python projects use packages to organize code into multiple modules that can be imported where needed, and the tutorial will do this as well.

The project directory will contain:

  • flaskr/, a Python package containing your application code and files.

  • tests/, a directory containing test modules.

  • .venv/, a Python virtual environment where Flask and other dependencies are installed.

  • Installation files telling Python how to install your project.

  • Version control config, such as git. You should make a habit of using some type of version control for all your projects, no matter the size.

  • Any other project files you might add in the future.

By the end, your project layout will look like this:

shell
/home/user/Projects/flask-tutorial
โ”œโ”€โ”€ flaskr/
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ db.py
โ”‚   โ”œโ”€โ”€ schema.sql
โ”‚   โ”œโ”€โ”€ auth.py
โ”‚   โ”œโ”€โ”€ blog.py
โ”‚   โ”œโ”€โ”€ templates/
โ”‚   โ”‚   โ”œโ”€โ”€ base.html
โ”‚   โ”‚   โ”œโ”€โ”€ auth/
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ login.html
โ”‚   โ”‚   โ”‚   โ””โ”€โ”€ register.html
โ”‚   โ”‚   โ””โ”€โ”€ blog/
โ”‚   โ”‚       โ”œโ”€โ”€ create.html
โ”‚   โ”‚       โ”œโ”€โ”€ index.html
โ”‚   โ”‚       โ””โ”€โ”€ update.html
โ”‚   โ””โ”€โ”€ static/
โ”‚       โ””โ”€โ”€ style.css
โ”œโ”€โ”€ tests/
โ”‚   โ”œโ”€โ”€ conftest.py
โ”‚   โ”œโ”€โ”€ data.sql
โ”‚   โ”œโ”€โ”€ test_factory.py
โ”‚   โ”œโ”€โ”€ test_db.py
โ”‚   โ”œโ”€โ”€ test_auth.py
โ”‚   โ””โ”€โ”€ test_blog.py
โ”œโ”€โ”€ .venv/
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ MANIFEST.in
/home/user/Projects/flask-tutorial
โ”œโ”€โ”€ flaskr/
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ db.py
โ”‚   โ”œโ”€โ”€ schema.sql
โ”‚   โ”œโ”€โ”€ auth.py
โ”‚   โ”œโ”€โ”€ blog.py
โ”‚   โ”œโ”€โ”€ templates/
โ”‚   โ”‚   โ”œโ”€โ”€ base.html
โ”‚   โ”‚   โ”œโ”€โ”€ auth/
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ login.html
โ”‚   โ”‚   โ”‚   โ””โ”€โ”€ register.html
โ”‚   โ”‚   โ””โ”€โ”€ blog/
โ”‚   โ”‚       โ”œโ”€โ”€ create.html
โ”‚   โ”‚       โ”œโ”€โ”€ index.html
โ”‚   โ”‚       โ””โ”€โ”€ update.html
โ”‚   โ””โ”€โ”€ static/
โ”‚       โ””โ”€โ”€ style.css
โ”œโ”€โ”€ tests/
โ”‚   โ”œโ”€โ”€ conftest.py
โ”‚   โ”œโ”€โ”€ data.sql
โ”‚   โ”œโ”€โ”€ test_factory.py
โ”‚   โ”œโ”€โ”€ test_db.py
โ”‚   โ”œโ”€โ”€ test_auth.py
โ”‚   โ””โ”€โ”€ test_blog.py
โ”œโ”€โ”€ .venv/
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ MANIFEST.in

If youโ€™re using version control, the following files that are generated while running your project should be ignored. There may be other files based on the editor you use. In general, ignore files that you didnโ€™t write. For example, with git:

shell
# .gitignore
.venv/

*.pyc
__pycache__/

instance/

.pytest_cache/
.coverage
htmlcov/

dist/
build/
*.egg-info/
# .gitignore
.venv/

*.pyc
__pycache__/

instance/

.pytest_cache/
.coverage
htmlcov/

dist/
build/
*.egg-info/

Continue to Application Setup.

Released under the MIT License.