python:如何处理时间戳(ISO8601)

标签 python timezone timestamp

我必须在 python 中处理代表 iso8601 的字符串时间戳。

因此,我的时间戳字符串采用以下形式:

timestamp = "2011-08-18T10:29:47+03:00"

目前我正在使用 python 转换它们:

timestamp = timestamp[:-6]
timestamp = datetime.datetime.strptime(timestamp, "%Y-%m-%dT%H:%M:%S")

但是这样我就失去了所有关于时区的信息。 我在 s-o 上看到了很多关于时间戳和 python 的例子,不幸的是没有人也保留时区,或者只是使用以下方法恢复时区延迟:

delay = timestamp[-6:]

我也试过:

timestamp = "2011-08-18T10:29:47+03:00"
timestamp = datetime.datetime.strptime(timestamp, "%Y-%m-%dT%H:%M:%S%z")

但它回来了

ValueError: 'z' is a bad directive in format '%Y-%m-%dT%H:%M:%S%z'

您能提供一些见解吗?

最佳答案

python iso8601模块是用一个很棒的 parse_date 方法构建的,它可以处理时区信息:

>>> import iso8601
>>> iso8601.parse_date("2007-01-25T12:00:00Z")
datetime.datetime(2007, 1, 25, 12, 0, tzinfo=<iso8601.iso8601.Utc ...>)

>>> iso8601.parse_date("2011-08-18T10:29:47+03:00")
datetime.datetime(2011, 8, 18, 10, 29, 47, tzinfo=<FixedOffset '+03:00'>)

如果你想在另一个时区转换它,使用 astimezone(tz)方法

如果您需要获取 UTC 日期时间,您可以使用 utctimetuple()方法。

关于python:如何处理时间戳(ISO8601),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11718909/

相关文章:

angularjs - Angular - 使用 i18n 和 l10n 进行日期时间和时区管理

command-line - PHP:系统时区设置错误

excel - 如何在excel中快速将UTC时间转换为本地时间?

r - 如何仅绘制包含日期的时间戳的时间部分?

python 列表连接

python - Pyspark 基于具有列表或集合的多个条件的其他列创建新列

Python:numpy/pandas 根据条件更改值

python - 深度复制后时间戳的 ruamel.yaml 格式似乎已损坏

sqlite - 如何将 Dart 的 `DateTime` 实例保存到 sqlite `timestamp` 字段?

python - 如何给 celery 中的每个节点命名