sql查取时间并进行相减后存入excel

本文介绍了一个用于计算两个日期间小时差的Python函数calculate。该函数接受两个日期参数,并返回它们之间的小时差。此外,还展示了如何使用SQL查询数据并利用pandas进行Excel文件的生成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里是封装成了一个函数

def calculate(date1, date2):
	detal = date2-date1
	#这里的时间为x day,xx:xx:xx的格式
	detal = str(detal)
	#拆分出天,其他为(xx:xx:xx)
	if len(detal.split(","))<=1:
		return str(detal)
	day,other = detal.split(",")
	#拆分出真正的天
	day = day.split(",")[0]
	#拆分出时分秒
	other = other.split(":")
	# 进行转换,将天转换为小时,再将之前的小时加过来
	hours = int (other[0]) + int(day) *24
	#最后替换成小时
	other[0] = str(hours)
	#返回最终结果
	return “:” .join(other)

封装sql那一段我就不写了,我的第一个博客里有
需要导入的模块里也有

..........
heards = (xxxxxx,xxxxx,xxx)
#data也就是sql语句
data =query ("select * form xxxxxxx")
genexcel = tablib.Dataset(*data, headers=headers)
datajson = json.loads(genexcel.json)
xlsx = xlwt.Workbook(encoding='utf-8')
sheet = xlsx.add_sheet('sheet1', True)
index = 1
	for row in data:
		#自己根据自己的sql的时间的列数,我的这边时间在3,4列,字段名叫created,date
		created,date = row[3],row[4]
		sheet.write(index,0,1,label = calculate(date1, date2) )
		index +=1
		xlsx.save("1.xls")

基本上就是这了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值