如何将 Django 的设置对象变成字典?

How do I turn django's settings object into a dict?

我有:

from django.conf import settings

def settings_to_dict(settings)
    cfg = {
        'BOTO3_ACCESS_KEY': settings.BOTO3_ACCESS_KEY,
        'BOTO3_SECRET_KEY': settings.BOTO3_SECRET_KEY,
        # repeat ad nauseum
    }
    return cfg

instance = SomeClassInstantiatedWithADict(**settings_to_dict(settings))

我想要什么(使用 Django 1.11):

from django.conf import settings

instance = SomeClassInstantiatedWithADict(**settings.to_dict())

我试过:

from django.conf import settings

instance = SomeClassInstantiatedWithADict(**settings.__dict__)

这很接近,但是 __dict__ 只得到一小部分设置,我认为这些设置是硬编码的,而不是添加的属性。感谢您的帮助!

这会将整个设置对象变成字典:

In [12]: settings_dict = {}

In [13]: for st in dir(settings):
    ...:     if st.startswith('_'):
    ...:         continue
    ...:     settings_dict[st] = getattr(settings, st)
    ...:
    ...:

In [14]: settings_dict

这非常详尽,包含所有可能的设置属性。

dir() 是一个 Python 内置函数。了解一下 here

在 shell 中勾选 settings.__dict__['_wrapped'].__dict__。里面好像什么都有。但是不确定这是否是正确的访问方式。

使用以下代码:

from django.conf import settings
instance = settings.__dict__['_wrapped'].__dict__

然后你将在 instance 中将整个设置字典作为字典。

>>> from django.conf import settings
>>> settings_dict = vars(settings._wrapped)
>>> print(settings_dict)
{'ABSOLUTE_URL_OVERRIDES': {}, 'ADMINS': [], 'ALLOWED_HOSTS': ['127.0.0.1', 'localhost', 'www.tetricoins.com', 'api.tetricoins.com'], 'APPEND_SLASH': True, ...

你确定你真的需要所有设置吗?

为什么不使用一个小帮手呢,你传入你需要的所有设置和一个默认值。像这样你总是得到一个你实际需要的设置的命令,即使它们没有配置。

    def build_settings_dict(attrs=[{'name': 'DEBUG', 'default': False},]):
        settings_dict = {}
        for attr in attrs:
            logger.info(attr)
            try:
                s = getattr(settings, attr['name'], attr['default'])
            except Exception as e:
                logger.warning("Error: %s", e)
            else:
                settings_dict[attr['name']] = s
        return settings_dict


    default_settings = build_settings_dict([
       {'name': 'DEBUG', 'default': True},
       {'name': 'USE_I18N', 'default': True},
       {'name': 'USE_L10N', 'default': False},
    ])