MASM32编程将TimeStamp/UTC转换为具体日期时间的几个有用函数代码

简介: MASM32编程将TimeStamp/UTC转换为具体日期时间的几个有用函数代码

这两天在编写一个读取系统事件日志的程序,其中结构变量EVENTLOGRECORD中成员TimeGenerated和TimeWritten的值为:

The time at which this entry was submitted. This time is measured in the number of seconds elapsed since 00:00:00 January 1, 1970, Universal Coordinated Time.

 

即从格林尼治时间1970年1月1日夜里12:00开始的秒数。

 

Windows系统好像没有直接提供将其转换为对应的年月日、时分秒的API函数。

Google了一下,在

 http://www.asmcommunity.net/board/index.php?topic=18369.0找到了donkey网友提供的方法,整理如下:

BaseTimeLow equ 0D53E8000h
BaseTimeHigh equ 19DB1DEh


StampToLocalDateTime proc dwStamp: dword, lpstLocalTime: dword
    local stUtcFileTime: FILETIME
    local stLocalFileTime: FILETIME

    mov eax, dwStamp
    mov edx,10000000
    mul edx
    add eax, BaseTimeLow
    adc edx, BaseTimeHigh

    mov stUtcFileTime.dwLowDateTime, eax
    mov stUtcFileTime.dwHighDateTime, edx
    invoke FileTimeToLocalFileTime, addr stUtcFileTime, addr stLocalFileTime
    invoke FileTimeToSystemTime, addr stLocalFileTime, lpstLocalTime

    ret
StampToLocalDateTime endp


LOCALE_SYSTEM_DEFAULT equ 0
g_szFmtDate db "yyyy-M-d", 0
printDate proc lpstDate: dword
    local buf[12]: byte
    invoke GetDateFormat, LOCALE_SYSTEM_DEFAULT, NULL,    lpstDate, offset g_szFmtDate, addr buf, sizeof buf    
    m_InsTxt addr buf
    ret
printDate endp

;LOCALE_SYSTEM_DEFAULT equ 0
g_szFmtTime db "H:m:ss", 0
printTime proc lpstTime: dword
    local buf[9]: byte
    invoke GetTimeFormat, LOCALE_SYSTEM_DEFAULT, NULL, lpstTime, offset g_szFmtTime, addr buf, sizeof buf
    m_InsTxt addr buf
    ret
printTime endp


g_szFmtDateTime db "%d-%d-%d %d:%d:%d", 0
printDateTime proc lpstDateTime: DWORD
    local buf[30]: byte

    pusha
    mov edi, lpstDateTime
    movzx eax, (SYSTEMTIME ptr [edi]).wYear
    movzx ebx, (SYSTEMTIME ptr [edi]).wMonth
    movzx ecx, (SYSTEMTIME ptr [edi]).wDay 
    movzx edx, (SYSTEMTIME ptr [edi]).wHour
    movzx esi, (SYSTEMTIME ptr [edi]).wMinute
    movzx edi, (SYSTEMTIME ptr [edi]).wSecond

    invoke wsprintf, addr buf, addr g_szFmtDateTime, eax, ebx, ecx,edx, esi, edi
    popa

    ret
printDateTime endp
相关文章
time模块与datetime模块,字符串与日期类型转换
time模块与datetime模块,字符串与日期类型转换
|
30天前
|
JavaScript 前端开发
QML中的Date将时间戳和指定格式时间互转
QML中的Date将时间戳和指定格式时间互转
33 0
|
4月前
|
安全 Python
Python如何使用datetime模块进行日期和时间的操作
Python如何使用datetime模块进行日期和时间的操作
51 1
|
4月前
|
定位技术 数据处理 Python
Python中的`datetime`模块:深入探索日期和时间操作
在Python中,处理日期和时间是一项常见的任务。`datetime`模块提供了丰富的类和方法,使得我们可以轻松地创建、解析、操作格式化日期和时间对象。这个模块在数据处理、时间戳转换、定时任务等多个领域都有着广泛的应用。
|
10月前
|
Python
Python3时间戳转换为指定格式的日期
Python3时间戳转换为指定格式的日期
|
11月前
|
前端开发 定位技术
前端将UTC时间格式转化为本地时间格式~~uniapp写法
前端将UTC时间格式转化为本地时间格式~~uniapp写法
106 0
|
Python
Python 3,一行代码处理各种时间转换,从此跟datetime,time模块说拜拜 ~ ~ 不收藏算我输!!!
Python 3,一行代码处理各种时间转换,从此跟datetime,time模块说拜拜 ~ ~ 不收藏算我输!!!
364 1
Python 3,一行代码处理各种时间转换,从此跟datetime,time模块说拜拜 ~ ~ 不收藏算我输!!!
|
存储 SQL 关系型数据库
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(上)
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(上)
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(上)
|
存储 SQL 关系型数据库
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(下)
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(下)
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(下)
|
存储 SQL 安全
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(中)
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(中)
【方向盘】MySql数据类型---日期时间类型的使用(含datetime和timestamp的区别) 0000-00-00 00:00:00问题解释(中)