lua 来回 UTC 日期
Back and forth UTC dates in lua
我在将 lua 日期转换为时间戳然后从中取回原始日期时遇到问题。它适用于非 UTC 日期,但不适用于 UTC。
目前我的示例代码是:
local dt1 = os.date( "*t" );
print( dt1.hour );
local dt2 = os.date( "*t", os.time( dt1 ) );
print( dt2.hour );
print( "-=-=-" );
local dt1 = os.date( "!*t" );
print( dt1.hour );
local dt2 = os.date( "!*t", os.time( dt1 ) );
print( dt2.hour );
local dt2 = os.date( "*t", os.time( dt1 ) );
print( dt2.hour );
产生输出:
12
12
-=-=-
10
9
11
因此,在第二部分中,使用 os.time( os.date( "!*t" ) )
获取时间戳后;我不知道如何获得原始日期。我做错了什么?
我发现在这个日期、时间和时区工作的唯一解决方案是使用自定义 c-build 方法:
例如,要以想要的格式检索字符串,我使用此方法:
static int idateformat(lua_State *L) {
time_t t0 = (time_t) lua_tonumber(L,1);
const char* ptrn = lua_tostring(L,2);
const char *tz_value = lua_tostring(L,3);
int isinenv = 0;
if(getenv("TZ") != NULL){
isinenv = 1;
}
char old_tz[64];
if (isinenv == 1) {
strcpy(old_tz, getenv("TZ"));
}
setenv("TZ", tz_value, 1);
tzset();
char new_tz[64];
strcpy(new_tz, getenv("TZ"));
struct tm *lt = localtime(&t0);
//"%Y-%m-%d %H:%M:%S"
char buffer[256];
strftime(buffer, sizeof(buffer), ptrn, lt);
if (isinenv == 1) {
setenv("TZ", old_tz, 1);
tzset();
}
//printf("%ld = %s (TZ=%s)\n", (long)t0, buffer, new_tz);
lua_pushstring(L, buffer);
return 1;
}
只有这样我会建议。
你没有做错任何事。
Lua 使用 ISO C 和 POSIX 日期和时间函数。特别是,os.time
使用 mktime
,它仅根据环境变量 TZ
中的当前时区设置来解释输入结构。不幸的是,这些标准没有提供根据 GMT/UTC.
解释输入结构的函数
在 Lua
中与 "date tables" 合作
设dt
为"date table"。
例如,os.date("*t")
返回的值是 "date table"。
如何归一化"date table"
例如,当前时间加1.5小时后
local dt = os.date("*t"); dt.min = dt.min + 90
您需要规范化 table 字段。
function normalize_date_table(dt)
return os.date("*t", os.time(dt))
end
这个函数 returns new date table 等价于它的参数 dt
而不管 dt
内容的含义:是否包含本地时间或 GMT 时间.
如何将Unix时间转换为"local date table"
dt = os.date("*t", ux_time)
如何将Unix时间转换为"GMT date table"
dt = os.date("!*t", ux_time)
如何将"local date table"转换为Unix时间
ux_time = os.time(dt)
如何将"GMT date table"转换为Unix时间
-- for this conversion we need precalculated value "zone_diff"
local tmp_time = os.time()
local d1 = os.date("*t", tmp_time)
local d2 = os.date("!*t", tmp_time)
d1.isdst = false
local zone_diff = os.difftime(os.time(d1), os.time(d2))
-- zone_diff value may be calculated only once (at the beginning of your program)
-- now we can perform the conversion (dt -> ux_time):
dt.sec = dt.sec + zone_diff
ux_time = os.time(dt)
我在将 lua 日期转换为时间戳然后从中取回原始日期时遇到问题。它适用于非 UTC 日期,但不适用于 UTC。
目前我的示例代码是:
local dt1 = os.date( "*t" );
print( dt1.hour );
local dt2 = os.date( "*t", os.time( dt1 ) );
print( dt2.hour );
print( "-=-=-" );
local dt1 = os.date( "!*t" );
print( dt1.hour );
local dt2 = os.date( "!*t", os.time( dt1 ) );
print( dt2.hour );
local dt2 = os.date( "*t", os.time( dt1 ) );
print( dt2.hour );
产生输出:
12
12
-=-=-
10
9
11
因此,在第二部分中,使用 os.time( os.date( "!*t" ) )
获取时间戳后;我不知道如何获得原始日期。我做错了什么?
我发现在这个日期、时间和时区工作的唯一解决方案是使用自定义 c-build 方法:
例如,要以想要的格式检索字符串,我使用此方法:
static int idateformat(lua_State *L) {
time_t t0 = (time_t) lua_tonumber(L,1);
const char* ptrn = lua_tostring(L,2);
const char *tz_value = lua_tostring(L,3);
int isinenv = 0;
if(getenv("TZ") != NULL){
isinenv = 1;
}
char old_tz[64];
if (isinenv == 1) {
strcpy(old_tz, getenv("TZ"));
}
setenv("TZ", tz_value, 1);
tzset();
char new_tz[64];
strcpy(new_tz, getenv("TZ"));
struct tm *lt = localtime(&t0);
//"%Y-%m-%d %H:%M:%S"
char buffer[256];
strftime(buffer, sizeof(buffer), ptrn, lt);
if (isinenv == 1) {
setenv("TZ", old_tz, 1);
tzset();
}
//printf("%ld = %s (TZ=%s)\n", (long)t0, buffer, new_tz);
lua_pushstring(L, buffer);
return 1;
}
只有这样我会建议。
你没有做错任何事。
Lua 使用 ISO C 和 POSIX 日期和时间函数。特别是,os.time
使用 mktime
,它仅根据环境变量 TZ
中的当前时区设置来解释输入结构。不幸的是,这些标准没有提供根据 GMT/UTC.
在 Lua
中与 "date tables" 合作设dt
为"date table"。
例如,os.date("*t")
返回的值是 "date table"。
如何归一化"date table"
例如,当前时间加1.5小时后
local dt = os.date("*t"); dt.min = dt.min + 90
您需要规范化 table 字段。
function normalize_date_table(dt)
return os.date("*t", os.time(dt))
end
这个函数 returns new date table 等价于它的参数 dt
而不管 dt
内容的含义:是否包含本地时间或 GMT 时间.
如何将Unix时间转换为"local date table"
dt = os.date("*t", ux_time)
如何将Unix时间转换为"GMT date table"
dt = os.date("!*t", ux_time)
如何将"local date table"转换为Unix时间
ux_time = os.time(dt)
如何将"GMT date table"转换为Unix时间
-- for this conversion we need precalculated value "zone_diff"
local tmp_time = os.time()
local d1 = os.date("*t", tmp_time)
local d2 = os.date("!*t", tmp_time)
d1.isdst = false
local zone_diff = os.difftime(os.time(d1), os.time(d2))
-- zone_diff value may be calculated only once (at the beginning of your program)
-- now we can perform the conversion (dt -> ux_time):
dt.sec = dt.sec + zone_diff
ux_time = os.time(dt)