问题描述
我需要比较两次。我第一次从 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