-
Notifications
You must be signed in to change notification settings - Fork 72
/
Copy pathJEE_DateAdd.ahk
142 lines (124 loc) · 4.8 KB
/
JEE_DateAdd.ahk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
; Title: DateAdd/DateDiff with friendly format
; Link: https://www.autohotkey.com/boards/viewtopic.php?t=59825
; Author: JEE
; Date: 10.12.2018
; for: AHK_L
/*
q:: ;test DateAdd/DateDiff 'friendly' format functions
Loop, 100000
{
;vSec1 := Random(0, 2147483647) ;2147483647 / (86400*365.25) ;around 68.04965 years
;vSec2 := Random(0, 2147483647)
Random, vSec1, 0, 2147483647 ;2147483647 / (86400*365.25) ;around 68.04965 years
Random, vSec2, 0, 2147483647
vDate1 := DateAdd(2000, vSec1, "S")
vDate2 := DateAdd(2000, vSec1+vSec2, "S")
vDiff := JEE_DateDiffFriendly(vDate1, vDate2)
vDiffX := JEE_DateDiffFriendly(vDate1, vDate2, "ymd")
vDate2X := JEE_DateAddFriendly(vDate1, vDiff)
vDate1 := RegExReplace(vDate1, "(?<=..)..(?=.)", "$0 ")
vDate2 := RegExReplace(vDate2, "(?<=..)..(?=.)", "$0 ")
vDate2X := RegExReplace(vDate2X, "(?<=..)..(?=.)", "$0 ")
;if !(vDate2 = vDate2X) ;use this to show any date pairs where diff then add doesn't return original date
; MsgBox, % "ERROR at A_Index:`r`n" A_Index "`r`n" vDate1 "`r`n" vDate2 "`r`n" vDate2X "`r`n" vDiff ;"`r`n" vDiffX
MsgBox, % vDate1 "`r`n" vDate2 "`r`n" vDiff ;"`r`n" vDiffX
}
SoundBeep
return
*/
MsgBox, % JEE_DateAddFriendly("20180229", "3y")
;==================================================
;e.g. MsgBox, % JEE_DateAddFriendly(20010101, "3y") ;20040101000000
;e.g. MsgBox, % JEE_DateAddFriendly(20010101, "3y 3m 3d") ;20040404000000
;e.g. MsgBox, % JEE_DateAddFriendly(20010101, "3y 3m 3d 8h 8m 8s") ;20040404080808
;vDiff expects 1 to 6 space-separated digit sequences (any non-spaces/non-digits are ignored)
JEE_DateAddFriendly(vDate, vDiff){
local
static date := "date"
vDate := FormatTime(vDate, "yyyyMMddHHmmss")
vTemp := RegExReplace(vDiff, "[^\d ]") " 0 0 0 0 0"
oTemp := StrSplit(vTemp, " ")
vMonth := SubStr(vDate, 5, 2)
if (vMonth+oTemp.2 > 12)
vDate += (oTemp.2-12) * 100000000 + (oTemp.1+1) * 10000000000
else
vDate += oTemp.2 * 100000000 + oTemp.1 * 10000000000
Loop, 3
;if JEE_StrIsType(vDate, "date")
if vDate is %date%
break
else
vDate -= 1000000
return DateAdd(vDate, oTemp.3*86400+oTemp.4*3600+oTemp.5*60+oTemp.6, "S")
}
;==================================================
;e.g. MsgBox, % JEE_DateDiffFriendly(20060131, 20060220) ;0y 0m 20d 0h 0m 0s
;e.g. MsgBox, % JEE_DateDiffFriendly(20060201, 20060220) ;0y 0m 19d 0h 0m 0s
;e.g. MsgBox, % JEE_DateDiffFriendly(20060504, 20070707) ;1y 2m 3d 0h 0m 0s
;e.g. MsgBox, % JEE_DateDiffFriendly(20060504, 20070707, "y") ;1y
;e.g. MsgBox, % JEE_DateDiffFriendly(20060504, 20070707, "ym") ;1y 2m
;e.g. MsgBox, % JEE_DateDiffFriendly(20060504, 20070707, "ymd") ;1y 2m 3d
;note: vFormat expects 1 to 6 characters
JEE_DateDiffFriendly(vDateA, vDateB, vFormat:="ymdhms", ByRef vIsFirstBiggerOrEqual:=1){
local
static date := "date"
vDateA := FormatTime(vDateA, "yyyyMMddHHmmss")
vDateB := FormatTime(vDateB, "yyyyMMddHHmmss")
if !(StrLen(vDateA) = 14) || !(StrLen(vDateB) = 14)
return
vSec := DateDiff(vDateA, vDateB, "S")
vIsFirstBiggerOrEqual := (vSec >= 0)
if !vIsFirstBiggerOrEqual
vTemp := vDateA, vDateA := vDateB, vDateB := vTemp ;swap variables
, vSec := Abs(vSec)
oDateA := StrSplit(RegExReplace(vDateA, "(?<=..)..(?=.)", "$0|"), "|") ;add splits: e.g. 20060504030201 -> 2006|05|04|03|02|01
oDateB := StrSplit(RegExReplace(vDateB, "(?<=..)..(?=.)", "$0|"), "|")
;get year difference
vDiffYear := oDateA.1 - oDateB.1
if (SubStr(vDateA, 5) < SubStr(vDateB, 5))
vDiffYear--
;get month difference
vDiffMonth := oDateA.2 - oDateB.2
if (vDiffMonth < 0)
vDiffMonth += 12
if (SubStr(vDateA, 7) < SubStr(vDateB, 7))
if (vDiffMonth = 0)
vDiffMonth := 11
else
vDiffMonth--
;get day/hour/minute/second differences
vDateB += vDiffYear*10000000000
if (oDateB.2 + vDiffMonth <= 12)
vDateB += vDiffMonth*100000000
else
vDateB += (vDiffMonth-12)*100000000 + 10000000000
Loop, 3
;if JEE_StrIsType(vDateB, "date")
if vDateB is %date%
break
else
vDateB -= 1000000
vSec := DateDiff(vDateA, vDateB, "S")
vDiffDay := vSec // 86400
vDiffHour := Mod(vSec, 86400) // 3600
vDiffMin := Mod(vSec, 3600) // 60
vDiffSec := Mod(vSec, 60)
vFormat := "{}" RegExReplace(vFormat, ".(?=.)", "$0 {}") ;e.g. 'ymdhms' -> '{}y {}m {}d {}h {}m {}s'
return Format(vFormat, vDiffYear, vDiffMonth, vDiffDay, vDiffHour, vDiffMin, vDiffSec)
}
;==================================================
;commands as functions (AHK v2 functions for AHK v1) - AutoHotkey Community
;https://autohotkey.com/boards/viewtopic.php?f=37&t=29689
DateAdd(DateTime, Time, TimeUnits){
EnvAdd DateTime, %Time%, %TimeUnits%
return DateTime
}
DateDiff(DateTime1, DateTime2, TimeUnits){
EnvSub DateTime1, %DateTime2%, %TimeUnits%
return DateTime1
}
FormatTime(YYYYMMDDHH24MISS:="", Format:=""){
local OutputVar
FormatTime OutputVar, %YYYYMMDDHH24MISS%, %Format%
return OutputVar
}