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

标签 python string string-formatting

我正在使用字符串.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/

相关文章:

Python __str__ - 它可以有歧义吗?

python - Pandas :计算列中日期时间对象的频率

python - pip 从requirements.txt 安装文件时出错

c# - 当我在 C# 中使用今天的日期时,为什么时间会变成 0000

python - python 使用固定数量的数字格式化 float

python - 如何在 ModelForm 中使用 SplitArrayField

python - 从完整版本字符串中获取主要版本的子字符串

c++ - 高效的字符串截断算法,顺序删除相等的前缀和后缀

c - 在 C 中打印 char[] 的一部分的最简单方法

string - 如何在Kotlin中将字符串转换为实体