Django app works fine, but getting a TEMPLATE_* warning message

27,170

Solution 1

Set debug in OPTIONS dictionary of your templates settings.

DEBUG = True

TEMPLATES = [
    {
        ...
        'OPTIONS': {
            'debug': DEBUG,
        },
    },
]

Then remove this line from your settings to stop the warnings

TEMPLATE_DEBUG = DEBUG

See the Django docs for detailed instructions how to update your template settings.

Solution 2

remove APP_DIRS and add the loaders inside the templates. example:

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')]
        ,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
            'loaders': [
               'django_jinja.loaders.AppLoader',
                'django_jinja.loaders.FileSystemLoader',
            ]
        },
    },
]

Solution 3

From settings.py remove all this:

    TEMPLATE_DIRS = (
        os.path.join(BASE_DIR,  'templates'),
    )

Then add 'templates' here:

    TEMPLATES = [
    {
        ...
        'DIRS': [here],
        ...
            ],
        },
    },
]

Solution 4

This is the best solution:

Change this line to:

TEMPLATES[0]['OPTIONS']['debug'] = True

which should fix the warning.

I have found it here.

Solution 5

In my setting.py in django, there is not this script :

TEMPLATE_DEBUG = DEBUG

and

'debug': DEBUG, 'DEBUG': DEBUG, 'TEMPLATE_DEBUG': DEBUG

Maybe you can try to remove them and run it again.

Share:
27,170
codingcoding
Author by

codingcoding

Updated on August 26, 2020

Comments

  • codingcoding
    codingcoding almost 4 years

    When I use runserver, it gives this warning message:

    (1_8.W001) The standalone TEMPLATE_* settings were deprecated in Django 1.8 and the TEMPLATES dictionary takes precedence. You must put the values of the following settings into your default TEMPLATES dict: TEMPLATE_DEBUG.

    Quoth the Django Documentation:

    "TEMPLATE_DEBUG Deprecated since version 1.8: Set the 'debug' option in the OPTIONS of a DjangoTemplates backend instead."

    Here is my settings.py with my futile attempts to fix it:

    DEBUG = True
    
    TEMPLATE_DEBUG = DEBUG
    
    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'DIRS': [os.path.join(BASE_DIR, 'myapp/templates')],
            'APP_DIRS': True,
            'OPTIONS': {
                'context_processors': [
                    'django.template.context_processors.debug',
                    'django.template.context_processors.request',
                    'django.contrib.auth.context_processors.auth',
                    'django.contrib.messages.context_processors.messages',
                ],
                'debug': DEBUG,
                'DEBUG': DEBUG,
                'TEMPLATE_DEBUG': DEBUG
            },
        }, ]
    

    What am I missing here?

  • Maxim Agapov
    Maxim Agapov over 8 years
    Change this line to: "TEMPLATES[0]['OPTIONS']['debug'] = True" in <project name>/settings/dev.py