NSIS 获取系统时间

编译时使用系统时间字符串作为常量:
1. ${__TIME__} 常量代表形如 0:18:40 的时间,是脚本编译的时间。
如:Name "Setup ${__TIME__}",则安装程序为 Setup 后面跟当前时间的时分秒字符串。
2. 使用 !define 的 /date 参数。同上,也是定义常量,${__TIME__} 无法满足要求时使用。
如:!define /date CUR_TIME "%H:%M:%S",格式化出来的常量 ${CUR_TIME} 与例 1 中的 ${__TIME__} 类似。此处 %H:%M:%S 仅作示范,不代表只支持格式化时分秒。该参数具体支持的年月日时分秒及其位数等支持格式化字符串可参考:
http://msdn.microsoft.com/en-us/library/aa272978.aspx
*新手特别注意:以上两个例子中得到的时间均是编译时间,得到的值属于常量,编译到安装程序已经是实际的字符串,不管在何时何地执行,该常量以及引用该常量的字符串依旧为编译时的时间。即与你直接写成 Name "Setup 0:18:40" 作用相同,区别只是编译时常量是脚本编译时自动得到的当前时间。

安装程序运行时获取系统时间:
3. 调用 Windows API 来获取本机时间:

System::Alloc 16
System::Call kernel32::GetLocalTime(isR0)
System::Call *$R0(&i2.R1,&i2.R2,&i2.R3,&i2.R4,&i2.R5,&i2.R6,&i2.R7,&i2.R8)
System::Free $R0
MessageBox MB_OK "$R1年$R2月$R4日,星期$R3,$R5:$R6:$R7.$R8"


上述例子中获取了所有的日期字符串。如果您只想要你需要的值,只需要将上述 &i2.R1 等类似的字符串换成 &i2 即可。如果后面有连续值不获取可以省略掉不写(具体使用详见 System 插件的用法介绍)。

对 System 插件不熟悉者,以下给出三个参考示例:

System::Alloc 16
System::Call "kernel32::GetLocalTime(isR0)"
System::Call "*$R0(&i2.R1,&i2.R2,&i2,&i2.R4)"
System::Free $R0
MessageBox MB_OK "$R1年$R2月$R4日"
System::Alloc 16
System::Call "kernel32::GetLocalTime(isR0)"
System::Call "*$R0(&i2,&i2,&i2,&i2,&i2.R5,&i2.R6,&i2.R7)
System::Free $R0
MessageBox MB_OK "$R5:$R6:$R7"
System::Alloc 16
System::Call kernel32::GetLocalTime(isR0)
System::Call *$R0(&i2.R1,&i2.R2,&i2,&i2.R4,&i2.R5,&i2.R6,&i2.R7,&i2.R8)
System::Free $R0
MessageBox MB_OK "$R1年$R2月$R4日,$R5:$R6:$R7.$R8"


以上用法是在安装程序执行期间动态获取用户机上的本机时间,与运行时间地点无关。

原文地址:https://www.cnblogs.com/juin/p/2583814.html