通过HTML模板格式化日志

时间:2017-01-18 09:39:42

标签: python html amazon-web-services amazon-cloudwatch amazon-ses

我正在检索cloudwatch日志,然后将其放入记录器文件中,然后使用Amazon SES通过邮件发送它们。我想要一种在发送之前格式化logger的fileHandler的方法。我真的想要一个带有颜色和列的可读电子邮件......

logLevel = logging.INFO
logger1.setLevel(logLevel)
formatter = logging.Formatter(' :: %(levelname)s :: %(message)s')
fileHandler = os.path.join('/tmp/', 'error-logs.log')
fh = logging.handlers.RotatingFileHandler(fileHandler, maxBytes=0, backupCount=0)
fh.setLevel(logLevel)
fh.setFormatter(formatter)
logger1.addHandler(fh)

这就是我填写记录器的方式:

output = []
output.append(event['message'])
logger1.info(' | '.join(output))

用logger填充文件后,我发送这样的邮件:

for file in sorted(glob.glob(filehandler + '*'), key=os.path.getmtime):
            body = open(file, 'r').read()
            subject = objet+" %s" % (today.strftime("%Y-%m-%d"))
            for email in emailarg.split(','):
                response = ses.send_email(
                            Source = email,
                            Destination={
                                'ToAddresses': [
                                    email,
                                ],
                            },
                            Message={
                                'Subject': {
                                    'Data': subject
                                },
                                'Body': {
                                    'Text': {
                                        'Data': body
                                    },
                                }
                            }
                        )

            os.remove(file)

您有什么方法可以使用HTML格式化日志文件(文本)吗?

1 个答案:

答案 0 :(得分:0)

我通过以下方式解决了问题:

  • 将HTML标记放在输出列表中(使用表标记)
  • 使用HTML作为AWS SES正文的Message格式,如下所示:
response = ses.send_email(
                          Source = email,
                          Destination={
                              'ToAddresses': [
                                  email,
                              ],
                          },
                          Message={
                              'Subject': {
                                  'Data': subject
                              },
                              'Body': {
                                  'Html': {
                                      'Data': body
                                  },
                              }
                          }
                      )