首页 > 解决方案 > 比较 time1(来自 API 请求)和 time2(SQL 请求)

问题描述

我需要比较两次。我第一次从 API 接收并具有以下格式:

time_api = ["2021-03-17T22:15:56.4477742Z","2020-04-28T08:12:17.0722131Z"]

由于我收到的结果是一个包含更多时间戳的列表,因此我在这里编写了一个仅包含两个元素的列表作为示例。

我第二次从 SQL 表接收并具有以下格式:

time_sql = "2021-03-17 22:15:56.4477742"

基于字符串的比较不起作用

if time_sql in time_api:
    print("foo")

我看过这些方法,但我还没有完全理解它们:

任何想法如何解决这个问题?谢谢

标签: python-3.xtimestampcompare

解决方案


从您的问题来看,在比较之前是否要将输入转换为时间/日期表示尚不清楚 -

如果您想将它们作为字符串进行比较 - 那么您可以执行以下操作:

time_api_modified = [_.replace('T', ' ').replace('Z', '') for _ in time_api]
time_api_modified
# ['2021-03-17 22:15:56.4477742', '2020-04-28 08:12:17.0722131']

time_sql = "2021-03-17 22:15:56.4477742"
time_sql in time_api_modified
# True

如果您确实想在比较之前转换为时间或日期表示,那么您可以查看使用该dateutil库 -

from dateutil.parser import *
time_api_modified = [parse(_, ignoretz=True) for _ in time_api]
time_sql = parse(time_sql)
time_sql in time_api_modified
# True

推荐阅读