A consistent file structure for your projects makes you well organized and more productive. When you have the basic workflow defined, you can get stuck into the business logic more quickly and create awesome projects.
Creating a project file structure
Getting ready
If you haven't done it yet, create a ~/projects directory, where you will keep all your Django projects (you can read about this in the Working with a virtual environment recipe).
Then, create a directory for your specific projectβfor example, myproject_website. Start the virtual environment in an env directory there. Activate it and install Django there, as described in the previous recipe. We would suggest adding a commands directory for local shell scripts that are related to the project, a db_backups directory for database dumps, a mockups directory for website design files, and, most importantly, an src directory for your Django project.
How to do it...
Follow these steps to create a file structure for your project:
- With the virtual environment activated, go to the src directory and start a new Django project, as follows:
(env)$ django-admin.py startproject myproject
The executed command will create a directory called myproject, with project files inside. This directory will contain a Python module, also called myproject. For clarity and convenience, we will rename the top-level directory as django-myproject. It is the directory that you will put under version control, and so it will have a .git or similarly named subdirectory.
- In the django-myproject directory, create a README.md file to describe your project to the new developdjango-admin.py startproject myprojecters.
- The django-myproject directory will also contain the following:
- Your project's Python package, named myproject.
- Your project's pip requirements with the Django framework and other external dependencies (read about this in the Handling project dependencies with pip recipe).
- The project license in a LICENSE file. If your project is open source, you can choose one of the most popular licenses from https://choosealicense.com.
- In your project's root, django-myproject, create the following:
- A media directory for project uploads
- A static directory for collected static files
- A locale directory for project translations
- An externals directory for external dependencies that are included in this project when you can't use the pip requirements
- The myproject directory should contain these directories and files:
- The apps directory where you will put all your in-house Django apps for the project. It is recommended that you have one app called core or utils for the projects' shared functionality.
- The settings directory for your project settings (read about this in the Configuring settings for development, testing, staging, and production environments recipe).
- The site_static directory for project-specific static files.
- The templates directory for the project's HTML templates.
- The urls.py file for the project's URL configuration.
- The wsgi.py file for the project's web server configuration.
- In your site_static directory, create the site directory as a namespace for site-specific static files. Then, we will divide the static files between the categorized subdirectories within it. For instance, see the following:
- scss for Sass files (optional)
- css for the generated minified Cascading Style Sheets (CSS)
- img for styling images, favicons, and logos
- js for the project's JavaScriptdjango-admin.py startproject myproject
- vendor for any third-party module combining all types of files, such as the TinyMCE rich-text editor
- Besides the site directory, the site_static directory might also contain overwritten static directories of third-party appsβfor example, it might contain cms, which overwrites the static files from Django CMS. To generate the CSS files from Sass and minify the JavaScript files, you can use the CodeKit (https://codekitapp.com/) or Prepros (https://prepros.io/) applications with a graphical user interface.
- Put your templates that are separated by the apps in your templates directory. If a template file represents a page (for example, change_item.html or item_list.html), then put it directly in the app's template directory. If the template is included in another template (for example, similar_items.html), put it in the includes subdirectory. Also, your templates directory can contain a directory called utils for globally reusable snippets, such as pagination and the language chooser.
How it works...
The whole file structure for a complete project will look similar to the following:
myproject_website/
βββ commands/
βββ db_backups/
βββ mockups/
βββ src/
β βββ django-myproject/
β βββ externals/
β β βββ apps/
β β β βββ README.md
β β βββ libs/
β β βββ README.md
β βββ locale/
β βββ media/
β βββ myproject/
β β βββ apps/
β β β βββ core/
β β β β βββ __init__.py
β β β β βββ versioning.py
β β β βββ __init__.py
β β βββ settings/
β β β βββ __init__.py
β β β βββ _base.py
β β β βββ dev.py
β β β βββ production.py
β β β βββ sample_secrets.json
β β β βββ secrets.json
β β β βββ staging.py
β β β βββ test.py
β β βββ site_static/
β β β βββ site/
β β β django-admin.py startproject myproject βββ css/
β β β β βββ style.css
β β β βββ img/
β β β β βββ favicon-16x16.png
β β β β βββ favicon-32x32.png
β β β β βββ favicon.ico
β β β βββ js/
β β β β βββ main.js
β β β βββ scss/
β β β βββ style.scss
β β βββ templates/
β β β βββ base.html
β β β βββ index.html
β β βββ __init__.py
β β βββ urls.py
β β βββ wsgi.py
β βββ requirements/
β β βββ _base.txt
β β βββ dev.txt
β β βββ production.txt
β β βββ staging.txt
β β βββ test.txt
β βββ static/
β βββ LICENSE
β βββ manage.py
βββ env/
There's more...
To speed up the creation of a project in the way we just described, you can use the project's boilerplate from https://github.com/archatas/django-myproject. After downloading the code, perform a global search and replace myproject with a meaningful name for your project, and you should be good to go.
See also
- The Handling project dependencies with pip recipe
- The Including external dependencies in your project recipe
- The Configuring settings for development, testing, staging, and production environments recipe
- The Deploying on Apache with mod_wsgi for the staging environment recipe in Chapter 12, Deployment
- The Deploying on Apache with mod_wsgi for the production environment recipe in Chapter 12, Deployment
- The Deploying on Nginx and Gunicorn for the staging environment recipe in Chapter 12, Deployment
- The Deploying on Nginx and Gunicorn for the production environment recipe in Chapter 12, Deployment