gpt4 book ai didi

python - 在 Python 中使用 str.format() 时的 HTML 转义替换字段

转载 作者:太空宇宙 更新时间:2023-11-03 19:33:32 25 4
gpt4 key购买 nike

我正在使用字符串.format()函数使用关键字参数格式化我的字符串。我将一些基本对象传递给字符串,并在字符串中使用这些对象的属性。例如:

"Hello, {user.first_name}!".format(user=my_user)

这些字符串可能会在 HTML 电子邮件中使用,因此替换字段应该是 HTML 转义的(使用 django.utils.html.escape)。

格式化字符串时,对字符串替换字段使用转义函数的最佳方法是什么?如果这不可能,那么字符串格式化的适当替代方案是什么?我的字符串存储在数据库中并通过 Django 管理界面进行修改。

最佳答案

嗯,问题是你为什么要使用格式。您不打算将其插入模板吗?我的意思是,如果您转义模板中的某些内容(使用模板标记),您几乎只是通过此转义函数传递一个字符串。

也许这不是您正在寻找的,但您不就这样做吗,

"Hello, {user.first_name}!".format(user=django.utils.html.escape(my_user))

如果你想逃避所有的争论并且你确信它们会是字符串,

def foo(**kwargs):
for key,val in kwargs.iteritems():
kwargs[key] = django.utils.html.escape(val)

...

你也可以做一些更疯狂的事情,比如,

def foo(**kwargs):
kwargs = dict((key, val) for key,val in izip(kwargs.iterkeys(), \
map(django.utils.htmls.escape, kwargs.itervalues())))

# OR if you use Python 3
kwargs = {key:django.utils.htmls.escape(val) for key, val in kwargs.items()}

如果你想让东西变得疯狂!

关于python - 在 Python 中使用 str.format() 时的 HTML 转义替换字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4632150/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com