如何将 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},
])
我有:
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},
])