这两天在用按键精灵手机助手写游戏脚本,需要计算时间差,先要获取两次时间,用系统自带的time()函数可以得到系统时间,不过得到的时间是秒数,需要转化一下
time()函数得到的是从1970年1月1日 8:00:00至今所经过的秒数
可以用DateTime.Format函数将Time()转为正常的时间格式
既然很容易就得到秒数,将两个时间相减就可以得到时间差了。
如果按键精灵手机助手每次获取电脑时间都很准确,我今天就不用写这篇文章了。我在运行游戏脚本时总是出错,检查之后才发现原因是获取的时间有问题
我电脑时间明明是16:17,怎么打印出来是9点
我把时间手动改为15:20点,显示还是9点
由于这个time()函数获取的时间不稳定,所以我决定用GetNetworkTime()函数,获取网络时间,然后计算时差。
获取时间容易,计算时间差难。因为按键精灵手机助手没有类似TimeDiff的函数,这一点希望按键精灵能改一下。于是我自己写代码计算时间差,代码可直接复制去使用。只要输入两个时间就行了,如果手动输入时间,必须为字符串,格式为"yyyy-mm-dd HH:MM:SS"
有闫年也可以正常计算出来
把秒换算成时分秒就简单了,这里就不写了
【总结】
1、可以有系统自带的time()函数获取系统时间,然后相减,得到时间差。这个方法时不时会出错
2、用下面我写的代码,可以手动输入时间,也可以获取网络时间,如果是手动输入时间,一定要注意格式
Dim t1,t2
//获取网络时间
//t1 = GetNetworkTime()
//自定义时间必须为字符串,格式为"yyyy-mm-dd HH:MM:SS"
t1 = "2024-02-28 00:00:00"//Delay 5000
//t2 = GetNetworkTime()//获取网络时间
t2 = "2024-03-01 00:00:00"
TracePrint "时间差为",ShiJianCha(t1,t2),"秒"Function ShiJianCha(time_1,time_2)Dim time_3, year_0, year_1, year_2, mon, mon1, mon2, mon3, day_1, day_2, day_3, yue1, yue2, ri1, ri2Dim hour_1, hour_2, hour_3, miniute_1, miniute_2, miniute_3, sec_1, sec_2, sec_3, TotalDaysDim ddd = 0//提取时间1的年月日时分秒TracePrint "time_1 =",time_1year_1 = Left(time_1, 4)+0mon1 = Mid(time_1, 6, 2)+0day_1 = Mid(time_1, 9, 2)+0hour_1 = Mid(time_1, 12, 2)+0miniute_1 = Mid(time_1, 15, 2)+0sec_1 = Mid(time_1, 18, 2)+0//提取时间2的年月日时分秒TracePrint "time_2=",time_2year_2 = Left(time_2, 4)+0mon2 = Mid(time_2, 6, 2)+0day_2 = Mid(time_2, 9, 2)+0hour_2 = Mid(time_2, 12, 2)+0miniute_2 = Mid(time_2, 15, 2)+0sec_2 = Mid(time_2, 18, 2)+0//计算秒数差If sec_2 - sec_1 >= 0 Then sec_3 = sec_2 - sec_1Else sec_3 = sec_2 - sec_1 + 60miniute_2 = miniute_2 - 1If miniute_2 < 0 Then miniute_2 = 59hour_2=hour_2-1End If End If//计算分钟数差If miniute_2 - miniute_1 >= 0 Then miniute_3 = miniute_2 - miniute_1Else miniute_3 = miniute_2 - miniute_1 + 60hour_2 = hour_2 - 1If hour_2 < 0 Then hour_2 = 23day_2 = day_2 - 1 End If End If//计算小时数差If hour_2 - hour_1 >= 0 Then hour_3 = hour_2 - hour_1 Else hour_3 = hour_2 - hour_1 + 24day_2 = day_2 - 1If day_2 = 0 Then mon2 = mon2 - 1TotalDays = TotalDays - 1 If mon2 <>0 Then day_2 = MeiYueTianShu(mon2,year_2)Else mon2 = 12day_2 = 31year_2 = year_2 - 1End IfEnd If End If//计算天数差For year_0 = year_1 To year_2 If year_0 = year_1 Then yue1 = mon1If year_1 = year_2 Then yue2 = mon2 Else yue2 = 12 End If ElseIf year_0 = year_2 If year_1 = year_2 Then yue1 = mon1 Else yue1 = 1 End Ifyue2 = mon2 Else yue1 = 1yue2 = 12End IfFor mon = yue1 To yue2If year_0 = year_1 and mon = mon1 Then ri1 = day_1If mon1 = mon2 Then ri2 = day_2 Else ri2 =MeiYueTianShu(mon,year_0) End If ElseIf year_0 = year_2 And mon = mon2 ThenIf mon1 = mon2 Then ri1 =day_1Else ri1 = 1End Ifri2 = day_2 Else ri1 = 1ri2 = MeiYueTianShu(mon,year_0) End IfFor ri = ri1 To ri2ddd = ddd + 1 Next Next NextTotalDays = ddd - 1ShiJianCha = ((TotalDays* 24 + hour_3) * 60 + miniute_3) * 60 + sec_3
End FunctionFunction MeiYueTianShu(mon,year_0)If mon = 4 or mon = 6 or mon = 9 or mon = 11 Then MeiYueTianShu = 30ElseIf mon = 2 ThenIf RunNian(year_0) Then MeiYueTianShu = 29Else MeiYueTianShu = 28 End IfElse MeiYueTianShu = 31 End If
End FunctionFunction RunNian(yyyy)If yyyy Mod 400 = 0 Then RunNian = True Else If yyyy Mod 4 = 0 And yyyy / 100 <> Int(yyyy / 100) Then RunNian = True Else RunNian = False End IfEnd If
End Function
把附件放在按键精灵手机助手里面的Plugin文件夹里,在使用之前导入一下,格式如下:
Dim t1,t2
Import "SC.lua"
t1 = GetNetworkTime() //获取网络时间
//自定义时间必须为字符串,格式为"yyyy-mm-dd HH:MM:SS"
t2 = "2024-03-01 02:18:20"
TracePrint SC.ShiJianCha(t1,t2)
附件下载地址:按键精灵手机助手计算时间差-VB文档类资源-CSDN下载