Настройки приложений Django
                                            
                                                
                                                
                                                
                                                
                                                
                                                 7591 단어  django
                    
비디오
Для всех последующих примеров кода предполагается, что выполнен импорт
settingsfrom django.conf import settings
Проблема
Если мы захотим использовать какую-то из настроек django в своём коде без упоминания его н еминания его н еминанть
# Обычно никто не задаёт значение для CSRF_COOKIE_AGE, 
print(settings.CSRF_COOKIE_AGE) # никаких ошибок, всё работает
Часто для своего приложения нужны свои настройки 1 . 설정에 관한 정보
print(getattr(settings, 'MY_APP_PARAM_1', default_value_of_param_1))
Выглядит как-то не очень, но если учесть, что одна и та же настройка может использоваться м в неск
# my_app/conf.py
default = {
    'MY_APP_PARAM_1': default_value_of_param_1,
    # Представьте, что здесь перечислены остальные настройки
}
def get_param_value(param_name):
    return getattr(settings, param_name, default_value_of_param_1)
# my_app/any_place.py
from .conf import get_param_value
print(get_param_value('MY_APP_PARAM_1')) # выглядит не очень, но работает
print(get_param_value('MY_APP_PARAM_L')) # IDE не помешает нам ошибиться
Хочется, чтобы работа с настройками была одинаковой для всех приложений 6, чтобы вид настройки.4был и чтобы работало автодополнение.
페이지
Я не стал придумывать велосипед, а взял чужой. Подозреваю, что на просторах PyPi можно найти ещё с десяток, е доэта лый чотому свой туда н забрасывать набрасывать
Скачать результат можно на github gist
Код в основном взят из django-rest-framework, из него выкинуто всё, что мешает переиспользованию. Файлик кладётся в папку доступную для всех приложений django. У меня это папка
settings.MY_APP_PARAM_1 .Посмотрим как это работает
# my_app\settings.py
from utils.django import AppSettings
# Описание настроек приложения.
# 1. Все поля находятся в одном месте
# 2. Видны все значения по умолчанию
# 3. При желании можно добавить типизацию
class MyAppSettings(AppSettings):
    URL = ''
    USER: str = ''
    PASSWORD = ''
# Объект с инициализированными данными 
# 1. Достаточно написать "conf." в любом IDE
#    и редактор сам предложит название настройки
# 2. Все обращения приложения к настройкам должны
#    происходить через этот объект, тогда не будет риска,
#    что приложение "сломается" из-за внешних факторов
conf = MyAppSettings('MY_APP_CONF')
# django_project\settings.py
# ...
# Настройки Django-проекта
# 1. Могут быть заданны частично
# 2. Могут быть совсем не заданы
# 3. Могут быть заданы явно, без использования .env
MY_APP_CONF = {
    'URL': env('MY_APP_URL', default=''),
    'USER': env('MY_APP_USER', default=''),
    'PASSWORD': env('MY_APP_PASSWORD', default=''),
}
# my_app\using.py
from .settings import conf
# Здесь создаётся условный клиент с подключением к некому сервису
client = get_data(conf.URL, conf.USER, conf.PASSWORD)
На что следует обратить внимание:
Я называю настройкой константу, которая влияет на поведение программы и значение которой мдо.жно
Reference
이 문제에 관하여(Настройки приложений Django), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/gimntut/django-1d66텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
                                
                                
                                
                                
                                
                                우수한 개발자 콘텐츠 발견에 전념
                                (Collection and Share based on the CC Protocol.)