Puede utilizar wsgiref.handlers.format_date_time del stdlib que no se basa en la configuración regional
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
puede utilizar email.utils.formatdate del stdlib que no se basa en la configuración regional
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
Si se puede establecer el proceso de configuración regional amplia, puede hacerlo:
import locale, datetime
locale.setlocale(locale.LC_TIME, 'en_US')
datetime.datetime.utcnow().strftime('%a, %d %b %Y %H:%M:%S GMT')
Si no desea establecer el proceso de configuración regional amplia que podría utilizar Babeldate formating
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'
de forma manual a formato lo que es idéntica a wsgiref.handlers.format_date_time es:
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)
Esta solución no funcionará por la razón que se describe en la pregunta: stftime depende de la configuración regional. –
es por eso que ocale.setlocale (locale.LC_TIME, 'en_US') –
Y es por eso que SO necesita un indicador de cuándo se editaron las respuestas. –