模块:ISODate
此Luazh-cn:模块; zh-tw:模組;在3,000个页面+中使用,修改会造成广泛的影响。请先在zh-cn:模块; zh-tw:模組;的/sandbox或者/testcases子页面测试。修改前请考虑至讨论页讨论变更。 |
本模块用于将各类日期转换为ISO 8601格式,以方便{{#time}}
函数和其他模板调用。
用法
输入完整日期,只输入年月、只输入年份皆可:
{{#invoke:ISODate|dates|1994年10月26日}}
→ 1994-10-26{{#invoke:ISODate|dates|1994年10月}}
→ 1994-10{{#invoke:ISODate|dates|1994年}}
→ 1994
当月和日是个位数时,十位加“0”或不加“0”皆可,模块会自动补“0”,
{{#invoke:ISODate|dates|1994年8月1日}}
→ 1994-08-01{{#invoke:ISODate|dates|1994年08月01日}}
→ 1994-08-01
可以转换英文和不规范的ISO 8601日期:
{{#invoke:ISODate|dates|October 26, 1994}}
→ 1994-10-26{{#invoke:ISODate|dates|26 Oct 1994}}
→ 1994-10-26{{#invoke:ISODate|dates|Sept 1994}}
→ 1994-09{{#invoke:ISODate|dates|1994-8-1}}
→ 1994-08-01{{#invoke:ISODate|dates|1994-8}}
→ 1994-08
如果字符串以正确的日期开头,则会转换并忽视后缀文字:
{{#invoke:ISODate|dates|1994年10月26日,武汉}}
→ 1994-10-26{{#invoke:ISODate|dates|1994年10月26日,武汉|suffix=yes}}
→ 1994-10-26,武汉(将suffix
字段设为yes
展示后缀)
以不合法日期开头则报错:
{{#invoke:ISODate|dates|一九九四年十月二十六日}}
→ 错误:无效时间。{{#invoke:ISODate|dates|1994年13月32日}}
→ 错误:无效时间。{{#invoke:ISODate|dates|一九九四年十月二十六日|error=ignore}}
→ 一九九四年十月二十六日(将error
字段设为ignore
返回输入值)
ISO 8601标准只规定了1583年之后的日期标准,请勿用本模块表示这之前的日期,否则可能会得到不期待的结果:
{{#invoke:ISODate|dates|25年8月5日(东汉建立)|suffix=yes}}
→ 0023-08-05(东汉建立)
require('Module:No globals')
local getArgs = require('Module:Arguments').getArgs
local p = {}
local function toISO(format, string)
return mw.getCurrentFrame():callParserFunction('#time', format, string)
end
local function convert(input)
input = input:gsub(" "," ");
input = input:gsub("%s+"," ");
local y, m, d, suf
local datePatternList = {
-- English date format
{'%d%d? ?%a+[ ,]*%d+', 'Y-m-d'}, -- 26 Oct 1994
{'%a+ ?%d%d?[ ,]+%d+', 'Y-m-d'}, -- Oct 26, 1994
{'%a+[ ,]*%d%d%d%d+', 'Y-m'}, -- Oct 1994
{'%a+ ?%d%d?', 'Y-m-d'}, -- Oct 26
{'%d%d? *%a+', 'Y-m-d'}, -- 26 Oct
-- Slash or hyphen date format
{'%d+/%d%d?/%d+', 'Y-m-d'}, -- 1994/10/26 or 10/26/1994
{'%d+%.%d%d?%.%d+', 'Y-m-d'}, -- 1994.10.26 or 26.10.1994
{'%d%d?/%d%d?', 'Y-m-d'}, -- 10/26
{'%d+%-%d%d?%-%d+', 'Y-m-d'}, -- 1994-10-26 or 26-10-94
{'%d%d%d%d+%-%d%d?', 'Y-m'}, -- 1994-10
{'%d%d%d%d', 'Y'}, -- 1994
}
y, m, d, suf = string.match(input, '^(%d+)年(%d%d?)月(%d%d?)日(.*)$');
if y then
if #y < 4 then
y = string.rep(0, 4 - #y) .. y
end
return toISO('Y-m-d', y .. '-' .. m .. '-' .. d) , suf
end
y, m, suf = string.match(input, '^(%d+)年(%d%d?)月(.*)$');
if y then
if #y < 4 then
y = string.rep(0, 4 - #y) .. y
end
return toISO('Y-m', y .. '-' .. m) , suf
end
y, suf = string.match(input, '^(%d+)年(.*)$');
if y then
if #y < 4 then
y = string.rep(0, 4 - #y) .. y
end
return toISO('Y', y) , suf
end
for _, value in ipairs(datePatternList) do
local str, suf = string.match(input, '^(' .. value[1] .. ')(.*)$');
if str then
return toISO(value[2], str), suf
end
end
return toISO('Y-m-d', 'error')
end
function p.dates(frame)
local args = getArgs(frame)
return p._dates(args)
end
function p._dates(args)
local returnval, suf = convert(args[1])
local errorMessage = toISO('Y-m-d', 'error')
if returnval == errorMessage and args.error == 'ignore' then
return args[1]
end
return returnval .. (args.suffix and suf or '')
end
function p.dateAndSuffix(string)
return convert(string)
end
return p