5

我正在寻找一种在 Python 日志格式化程序中执行部分字符串格式化的方法。

尝试通过以下方式定义格式化程序时:

formatter = logging.Formatter('[num-%d] %(levelname)s %(message)s' % (num,))

我会得到一个带有“格式需要映射”的 TypeError,这是合理的,因为解释器找不到“级别名称”和“消息”。

当然,我希望 'levelname' 和 'message' 都保持未格式化以供日志框架处理。

如我所见,还有另外两种解决问题的方法:

  1. format = '[num-' + str(num) + '] %(levelname)s %(message)s' % (num,)
  2. format = '[num-%(num)d] %(levelname)s %(message)s' % dict(num=num, levelname='%(levelname)s', message='%(message)s')

但是,我发现这两种解决方案都有些难看,我相信必须有更好的方法来格式化字符串的一部分——无论是在 Python 中,还是在 python 内置日志框架中使用。

有任何想法吗?

4

1 回答 1

5

尝试这个:

formatter = logging.Formatter('[num-%d] %%(levelname)s %%(message)s' % (num,))

您必须为方法提供带有字段Formatter的字符串。遗嘱解释成,%(...)s因此可以使用。%%%

于 2011-08-24T13:09:13.813 回答