两个日期之间的月份分解

时间:2019-02-01 21:16:14

标签: lua

我需要一个循环,其中xy是两个输入变量,
现在我想得到一个结果数组,其中两个日期之间的所有时间段都以月为单位。
例如x = 1.1.2019y = 31.3.2019
结果将是数组 1.1.2019, 31.1.2019, 1.2.2019, 28.2.2019, 1.3.2019, 31.3.2019使用LUA编程语言。

1 个答案:

答案 0 :(得分:2)

x = os.time{year=2019, month=1, day=1}
y = os.time{year=2019, month=3, day=31}

df = {}
i = 2
sec_day = 24*60*60
df[1] = x
while x <= y do
     x = x +sec_day
     df[i] = x
     i = i+1
end

--loop to get unique months
hash={}
d_months = {}
for _,v in ipairs(df) do
    if (not hash[os.date('%m',v)]) then
        d_months[#d_months+1] = os.date('%m', v)
        hash[os.date('%m',v)] = true
    end
end

--now everything is set up and we can iterate over the months to get the start and end days of the month
min_d = {}
max_d = {}
for idx,month in ipairs(d_months) do
    min = nil
    max = nil
    for _,v in ipairs(df) do
         if os.date('%m', v) == month then
             min = min or v
             max = max or v
             min = min < v and min or v
             max = max > v and max or v
         end
     end
 min_d[idx] = os.date('%d.%m.%Y', min)
 max_d[idx] = os.date('%d.%m.%Y', max)
 print(os.date('%d.%m.%Y', min) .. " " .. os.date('%d.%m.%Y', max))
 end

评论以外的简短说明。首先,我们获得一个表格,其中包含开始日期和结束日期之间的每个日期。 在下一个循环中,我们正在寻找一系列独特的月份(请参见Lua : remove duplicate elements)。 最后,我们遍历所有日期的数组,并找到每个月的最小值和最大值。

输出

01.01.2019 31.01.2019
01.02.2019 28.02.2019
01.03.2019 31.03.2019

如果要使用数年,只需执行两个额外的循环即可。一旦您需要找到独特的年份,然后不仅需要比较几个月,还需要比较最后一部分中的年份。

编辑:更改了输出格式的格式。