鱼C论坛

 找回密码
 立即注册
查看: 599|回复: 6

python处理时间是否连续

[复制链接]
发表于 2024-6-29 03:20:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
求助大神,如何用python判断excel中相邻的单元格里面的时间是否连续,就是我打框的的时间,判断他们是否一致
微信图片_20240629031838.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2024-6-29 03:20:34 | 显示全部楼层
要在 Python 中判断 Excel 表格中相邻单元格的时间是否连续,可以使用 `pandas` 库来读取 Excel 文件,并对时间进行处理和比较。以下是一个简单的示例代码,帮助你实现这一功能。

首先,确保你已经安装了 `pandas` 和 `openpyxl` 库:

  1. pip install pandas openpyxl
复制代码


然后,使用以下代码来判断 Excel 中相邻单元格的时间是否连续:

  1. import pandas as pd

  2. # 读取Excel文件
  3. file_path = '你的excel文件路径.xlsx'
  4. df = pd.read_excel(file_path)

  5. # 假设你的时间列名为 'Time',并且时间格式为datetime类型
  6. # 你可以根据你的实际情况调整列名和时间格式
  7. df['Time'] = pd.to_datetime(df['Time'])

  8. # 判断相邻单元格时间是否连续
  9. df['Is_Continuous'] = df['Time'].diff().dt.total_seconds().fillna(0) <= 60  # 假设连续的定义是间隔不超过60秒

  10. # 打印结果
  11. print(df)

  12. # 如果需要保存结果到新Excel文件
  13. df.to_excel('检查结果.xlsx', index=False)
复制代码


这个代码的基本思路如下:

1. 使用 `pandas` 读取 Excel 文件,并假设时间列的名称为 `'Time'`(你需要根据实际情况调整列名)。
2. 将时间列转换为 `datetime` 类型,便于后续计算。
3. 使用 `diff()` 方法计算相邻时间的差异,并判断差异是否在允许的连续时间范围内(例如 60 秒)。
4. 将结果存储在新的列 `'Is_Continuous'` 中,其中 `True` 表示时间连续,`False` 表示时间不连续。
5. 最后,你可以选择将结果保存到新的 Excel 文件中。

请根据你的实际需求调整代码,比如时间列的名称、连续时间的定义等。这样,你就可以轻松判断 Excel 表格中相邻单元格的时间是否连续了!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-6-29 06:48:27 | 显示全部楼层
我怎么题目都看不懂,什么叫时间连续
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-6-29 17:50:01 | 显示全部楼层
  1. from datetime import datetime


  2. def isSameDate(x: str, y: str) -> bool:
  3.     '''
  4.     x = '2023/11/3-2023/11/11'
  5.     y = '2023/11/11-2023/11/24'
  6.     '''
  7.     f = lambda z: datetime.strptime(z, '%Y/%m/%d')
  8.     date_x, date_y = x.split('-'), y.split('-')
  9.     return f(date_x[-1]) == f(date_y[0]) or f(date_x[0]) == f(date_y[-1])


  10. if __name__ == '__main__':
  11.     a = '2023/11/3-2023/11/11'
  12.     b = '2023/11/11-2023/11/24'
  13.     c = '2023/11/24-2023/12/21'

  14.     print(isSameDate(a, b))
  15.     print(isSameDate(b, c))
  16.     print(isSameDate(a, c))


  17. ==================== RESTART: C:\Users\user\Desktop\test.py ====================
  18. True
  19. True
  20. False
  21. >>>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-6-30 18:04:05 | 显示全部楼层
stumblemodel 发表于 2024-6-29 06:48
我怎么题目都看不懂,什么叫时间连续

就是红框框和黄框框里面的时间时相同的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-6-30 18:04:44 | 显示全部楼层

但是数据实在excel表中呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-7-3 00:51:28 | 显示全部楼层
pallas 发表于 2024-6-30 18:04
但是数据实在excel表中呢?
  1. from datetime import datetime
  2. import openpyxl


  3. def isSameDate(x: str, y: str) -> bool:
  4.     '''
  5.     x = '2023/11/3-2023/11/11'
  6.     y = '2023/11/11-2023/11/24'
  7.     '''
  8.     f = lambda z: datetime.strptime(z, '%Y/%m/%d')
  9.     date_x, date_y = x.split('-'), y.split('-')
  10.     return f(date_x[-1]) == f(date_y[0]) or f(date_x[0]) == f(date_y[-1])


  11. def getData(p: str='./data.xlsx', r: int=0 , c: str='', isTitle: bool=True) -> list:
  12.     '''
  13.     p = 'D:/data.xlsx' # str 填写Excel表格路径
  14.     r = 1 # int 填写日期在第几行,填写了行就不要再填写列
  15.     c = 'A' # str 填写日期在第几列,填写了列就不要再填写行
  16.     isTitle = True # bool 填写是否含有表头,是为True否为False
  17.     '''
  18.     sheet = openpyxl.load_workbook(p).active
  19.     if r and c:
  20.         return []
  21.     elif r:
  22.         data = sheet[r]
  23.     elif c:
  24.         data = sheet[c]
  25.     else:
  26.         return []
  27.     res = [d.value for d in data]
  28.     return res[1:] if isTitle else res

  29.    
  30. if __name__ == '__main__':
  31.     a = '2023/11/3-2023/11/11'
  32.     b = '2023/11/11-2023/11/24'
  33.     c = '2023/11/24-2023/12/21'

  34.     print(isSameDate(a, b))
  35.     print(isSameDate(b, c))
  36.     print(isSameDate(a, c))

  37.     path = 'data.xlsx'
  38.     data_1 = getData(p=path, r=1) # 读取表格中(有表头)第1行的数据
  39.     data_A = getData(p=path, c='A', isTitle=False) # 读取表格中(无表头)第A列的数据
  40.    
  41.     for i1 in range(len(data_1)-1):
  42.         a, b = data_1[i1], data_1[i1+1]
  43.         print(1, a, b, isSameDate(a, b))
  44.               
  45.     for iA in range(len(data_A)-1):
  46.         a, b = data_A[iA], data_A[iA+1]
  47.         print('A', a, b, isSameDate(a, b))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 01:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表