python-3.x - 比较 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")
我看过这些方法,但我还没有完全理解它们:
- 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
推荐阅读
- javascript - HTML - ReactJS:如何在
- c# - 我可以使用 WebView 接收推送通知并使用 Xamarin 在我的 Android 应用程序上显示它们吗?
- vue.js - VuePress - 用特殊字符填充的降价内容
- kubernetes - 裸机上的 Kubernetes,通过入口暴露服务
- docker - 如何使用在 docker 中退出的同一个容器
- google-cloud-platform - 将 OpenVPN 与 Google VPC 连接后,无法上网
- javascript - 如何根据 id 显示图像(过滤器)
- javascript - 使用javascript on.change函数的总和显示为00.000.000.00,任何人都可以解释它并给出解决方案吗?
- c++ - 此代码编译正常但文件未创建?请指出错误
- google-cloud-platform - 转移存储桶的所有权和计费