钉钉考勤表 打卡时间转换为工时

钉钉打卡工时统计,表1为原始打卡记录,怎么用Python或者VBA生成表2工时格式。

早上上班时间为7:00,下班时间为11:30,下午上班时间为13:30下班时间为17:30,如果有加班加班时间为18:00-20:30。

中午休息1.5小时,晚上如果有加班,下午下班有0.5小时吃饭时间。

正常考勤为每天工作9小时,如果加班工作为11.5小时。

可以使用DateDiff函数,先看代码:

Sub 时间减法()
  Dim tS As Date
  Dim tE As Date
  tS = TimeSerial(Hour(Cells(1, 1).Value), Minute(Cells(1, 1).Value), 0) '开始时间 6:47:00
  tE = TimeSerial(Hour(Cells(1, 2).Value), Minute(Cells(1, 2).Value), 0) '结束时间 17:30:00
  Dim span As Long
  span = datediff("n", tS, tE) '计算出自开始至结束共有多少分钟,结果为643分钟
End Sub

我在你发的图中选择“员工1”在“1日”那天的开始时间填入Excel的A1单元格,结束时间填入Excel的B1单元格,然后运行此代码,得出共计643分钟。

我最开始使用的是按小时作为间隔,多次测试发现DateDiff函数返回的就是整数,没有小数位,为了员工的小小的利益着想,还是按照分钟计算,然后再将分钟自行转成带有小数位的小时吧。

希望能帮助到你!

你用excel处理,每天的上下班打卡时间做个减法,再累加一个月不就行了吗

建议用vba,这个最方便

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y