我的 Django 应用程序中有一个函数,它有一个包含几个长字符串的字典。当调用该函数时,这些字符串被格式化并返回字典。
例如:
def my_strings(foo, bar, baz):
return = {
'string1': 'a really long string! %s' % foo,
'string2': 'another long one. %s %s' % (foo, bar),
'string3': 'yet another! %s %s %s' % (foo, bar, baz),
}
但是,将所有这些长字符串存储在 Python 文件中是很难看的,似乎应该有一种更简洁的方法来做到这一点。
我曾尝试将它们放入模板文件并进行一些渲染,如下所示:
我的模板.txt
{% if string1 %}
a really long string! {{ foo }}
{% endif %}
{% if string2 %}
another long one. {{ foo }} {{ bar }}
{% endif %}
{% if string3 %}
yet another! {{ foo }} {{ bar }} {{ baz }}
{% endif %}
Python
def my_strings(foo, bar, baz):
arg_dict = {
'foo': foo,
'bar': bar,
'baz': baz,
}
my_strings = {}
string_names = ['string1', 'string2', 'string3']
for s in string_names:
arg_dict[s] = True
my_strings[s] = render_to_string('mytemplate.txt', arg_dict).strip()
del arg_dict[s]
return my_strings
但这似乎有点过于迂回,而且很可能性能较差。
在 Python 或 Django 中是否有首选方法来处理存储和格式化长字符串资产?
一些额外的上下文:字符串资产是 HTML 或纯文本。字典最终被迭代,并且另一个字符串中每个键的所有实例都被替换为其字符串值。