Module:Spellnum per MOS
Jump to navigation
Jump to search
Documentation for this module may be created at Module:Spellnum per MOS/doc
local p = {} local words = {"thousand", "million", "billion", "trillion"} -- We don't need to go higher than this, no-one knows what an octillion is. -- For use by other scripts. Takes arguments: -- - 1: string or number, value to convert -- - forcenum: string for Template:Yesno, forces a result in digits for all n ≥ 10. -- - formating options for spellnum: zero, adj, ord, us function p.spellnum(args) local frame = mw.getCurrentFrame() local numeral = tonumber(args[1]) local pass_zero = "zero" if args['zero'] ~= nil and args['zero'] ~= '' then pass_zero = args['zero'] end -- Always return numerals for negative numbers, non-integers, and if (forcenum and numeral >= 10). if numeral < 0 or math.fmod(numeral, 1) ~= 0 or (numeral >= 10 and frame:expandTemplate{ title = 'yesno', args = {args['forcenum']} } == 'yes') then return mw.language.getContentLanguage():formatNum(numeral) end -- Convert numeral to words local spelled = frame:expandTemplate{ title = 'spellnum', args = { numeral, zero = pass_zero, adj = args['adj'], ord = args['ord'], us = args['us']}} -- Return numerals if more than two words would be needed, else return words if mw.ustring.find(spelled,'%a+[ %-]%a+[ %-]%a+') then -- Handle numbers larger than one million if numeral >= 1000000 and numeral <= 1000000000000000 then local size = math.min(4, math.floor(math.log10(numeral) / 3)) numeral = numeral / 1000^size return ({"%.1f ", "%d ", "%d "})[1 + math.floor(math.log10(numeral))]:format(numeral) .. words[size] end return mw.language.getContentLanguage():formatNum(numeral) else return spelled end end function p.main(frame) return p.spellnum(frame.args) end return p