比较 time1来自 API 请求与 time2SQL 请求

问题描述

我需要比较两次。我第一次从 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")

我已经大致了解了这些方法,但我还没有完全理解它们:

  • datetime.fromtimestamp(time_api[0])
  • datetime.datetime(time_api[0])

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

解决方法

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

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

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