首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >我们是否可以将apps.py用于应用程序级配置,而不是将settings.py用于项目级配置?

我们是否可以将apps.py用于应用程序级配置,而不是将settings.py用于项目级配置?
EN

Stack Overflow用户
提问于 2016-06-28 19:37:46
回答 1查看 3.9K关注 0票数 18

这个问题早些时候已经被问过了:What is the purpose of apps.py in Django 1.9?

应用程序配置对象存储应用程序的元数据。某些属性可以在AppConfig子类中配置。其他是由Django设置的,并且是只读的。

然而,应用程序的元数据是什么意思呢?是否仅限于这些AppConfig metadata:name, verbose_name, path, label, module, models_module

或者,在预定义的元数据之外进行扩展是否有意义,特别是对于特定于应用程序的元数据,例如,在blog应用程序中,我们有一个日期格式配置,通常定义如下:

代码语言:javascript
复制
# File: settings.py
BLOG = {
    'DATE_FORMAT': 'ddMMYYY',
}

它的用法如下:

代码语言:javascript
复制
# File: blog/<...>.py
from django.conf import settings
date_format = settings.BLOG['DATE_FORMAT']

相反,我们可以将此配置作为BlogConfig移到blog/apps.py

代码语言:javascript
复制
class BlogConfig(AppConfig):
    name = 'blog'
    verbose_name = 'Awesome Blog'
    date_format = 'ddMMYYYY'

因此,在应用程序中的所有代码中,date_format都由以下对象使用:

代码语言:javascript
复制
# File: blog/<...>.py
from django.apps import apps
date_format = apps.get_app_config('blog').date_format

在我看来,settings.py项目的设置,而不是应用程序设置。因此,将所有应用程序设置放在apps.py中比放在settings.py中听起来更合理。那么,对于我来说,将应用程序配置放在apps.py而不是settings.py中,这是一个有效的假设/参数/约定吗

EN

回答 1

Stack Overflow用户

发布于 2016-07-07 19:41:00

每个django安装的项目都是唯一的,而应用程序应该是可重用的。

如果您将自定义应用程序设置放在项目的settings.py中,则它们应该是可修改的,特别是当您(或其他人)将此应用程序重用于另一个项目时。

现在,如果你将这些自定义设置放在你的应用程序的apps.py中,这意味着它们将不能在每个项目的基础上进行修改。在这种情况下,没有理由将它们放在apps.py中,而不是放在constants子模块中。除非您想提供一组有限的可能配置:

代码语言:javascript
复制
class BlogConfig(AppConfig):
    name = 'blog'
    verbose_name = "Blog"
    date_format = 'ddMMYYYY'


class CustomizableDateFormatBlogConfig(BlogConfig):
    date_format = getattr(settings, 'BLOG_DATE_FORMAT', BlogConfig.date_format)


class I18nBlogConfig(BlogConfig)
    verbose_name = _("Blog")

default_app_config将是BlogConfig,但使用该应用程序的项目也可以选择CustomizableDateFormatBlogConfigI18nBlogConfig

然而,这使得可定制性很差的应用程序。在上面的示例中,如果您想让应用程序用户同时使用CustomizableDateFormatBlogConfigI18nBlogConfig,则需要执行以下操作:

代码语言:javascript
复制
class BlogConfig(AppConfig):
    name = 'blog'
    verbose_name = "Blog"
    date_format = 'ddMMYYYY'


class CustomizableDateFormatMixin:
    date_format = getattr(settings, 'BLOG_DATE_FORMAT', BlogConfig.date_format)


class I18nMixin:
    verbose_name = _("Blog")


class CustomizableDateFormatBlogConfig(CustomizableDateFormatMixin, BlogConfig):
    pass


class I18nBlogConfig(I18nMixin, BlogConfig):
    pass


class I18nCustomizableDateFormatBlogConfig(I18nMixin, CustomizableDateFormatMixin, BlogConfig):
    pass

因此,除了需要提供一组不同的应用程序配置的特定情况外,最好将自定义应用程序设置放在项目的settings.py中。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38075176

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档