Python中的RFC 1123日期表示法?
有没有简单的方法可以把一个日期时间对象转换成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)