Python中的RFC 1123日期表示法?

87 投票
5 回答
30754 浏览
提问于 2025-04-11 18:10

有没有简单的方法可以把一个日期时间对象转换成RFC 1123格式的日期时间字符串,也就是像下面这样的格式:

Sun, 06 Nov 1994 08:49:37 GMT

使用strftime这个方法不行,因为生成的字符串会受到地区设置的影响。我是不是得手动拼接这个字符串呢?

5 个回答

20

如果你正在做一个Django项目,Django提供了一个函数django.utils.http.http_date(epoch_seconds)

from django.utils.http import http_date

some_datetime = some_object.last_update
response['Last-Modified'] = http_date(some_datetime.timestamp())

这个函数使用了email.utils.formatdate,这两个是等价的:

from email.utils import formatdate

response['Last-Modified'] = formatdate(some_datetime.timestamp(), usegmt=True)
58

你可以使用Python标准邮件模块里的formatdate()函数:

from email.utils import formatdate
print formatdate(timeval=None, localtime=False, usegmt=True)

这个函数会以你想要的格式给出当前时间:

Wed, 22 Oct 2008 10:32:33 GMT

实际上,这个函数是“手动”完成这个任务的,没有使用strftime()这个函数。

100

你可以使用标准库中的wsgiref.handlers.format_date_time,这个方法不受地区设置的影响。

from wsgiref.handlers import format_date_time
from datetime import datetime
from time import mktime

now = datetime.now()
stamp = mktime(now.timetuple())
print format_date_time(stamp) #--> Wed, 22 Oct 2008 10:52:40 GMT

你也可以使用标准库中的email.utils.formatdate,这个方法同样不受地区设置的影响。

from email.utils import formatdate
from datetime import datetime
from time import mktime

now = datetime.now()
stamp = mktime(now.timetuple())
print formatdate(
    timeval     = stamp,
    localtime   = False,
    usegmt      = True
) #--> Wed, 22 Oct 2008 10:55:46 GMT

如果你可以在整个程序中设置地区,那么你可以这样做:

import locale, datetime

locale.setlocale(locale.LC_TIME, 'en_US')
datetime.datetime.utcnow().strftime('%a, %d %b %Y %H:%M:%S GMT')

如果你不想在整个程序中设置地区,你可以使用Babel日期格式化功能。

from datetime import datetime
from babel.dates import format_datetime

now = datetime.utcnow()
format = 'EEE, dd LLL yyyy hh:mm:ss'
print format_datetime(now, format, locale='en') + ' GMT'

还有一种手动格式化的方法,它和wsgiref.handlers.format_date_time是一样的:

def httpdate(dt):
    """Return a string representation of a date according to RFC 1123
    (HTTP/1.1).

    The supplied date must be in UTC.

    """
    weekday = ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"][dt.weekday()]
    month = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep",
             "Oct", "Nov", "Dec"][dt.month - 1]
    return "%s, %02d %s %04d %02d:%02d:%02d GMT" % (weekday, dt.day, month,
        dt.year, dt.hour, dt.minute, dt.second)

撰写回答