Module:NumberAbbr: Difference between revisions
Appearance
MisterChuChu (talk | contribs) Fix for inputs like "1.23456e11" resulting in "1.234B" instead of "123.456B" |
MisterChuChu (talk | contribs) Fix a bug related to calculating illion 999 |
||
(5 intermediate revisions by the same user not shown) | |||
Line 6: | Line 6: | ||
local s=f.args[3]~=nil and math.max(f.args[3],3) or 6 --start at 10^ | local s=f.args[3]~=nil and math.max(f.args[3],3) or 6 --start at 10^ | ||
local abt=f.args[4]==nil and false or f.args[4] --use abbr tag? | local abt=f.args[4]==nil and false or f.args[4] --use abbr tag? | ||
local ps=f.args[5]==nil and false or f.args[5] --add plus symbol to positive numbers? | |||
local chk=string.gsub(n,",","") --remove commas | |||
return | if tonumber(chk)==nil then --cancel abbreviation if number is invalid | ||
return n | |||
else | else | ||
local n2="" --create additional variables | local n2="" --create additional variables | ||
Line 19: | Line 21: | ||
n=string.sub(n,m+1,#n) --if so, remove minus at start | n=string.sub(n,m+1,#n) --if so, remove minus at start | ||
if string. | if string.find(n,"i")~=nil then --check if infinite | ||
nn=math.huge | nn=math.huge | ||
isinf=true | isinf=true | ||
Line 30: | Line 32: | ||
ep=string.find(nn,"e")~=nil and tonumber(string.sub(nn,string.find(nn,"e")+1,#nn)) or #nn>100 and #nn or math.floor(math.log10(nn)) --get exponent | ep=string.find(nn,"e")~=nil and tonumber(string.sub(nn,string.find(nn,"e")+1,#nn)) or #nn>100 and #nn or math.floor(math.log10(nn)) --get exponent | ||
if string. | if string.find(ep,"i")~=nil then --check if exponent is infinite | ||
nn=math.huge | nn=math.huge | ||
isinf=true | isinf=true | ||
Line 57: | Line 59: | ||
end | end | ||
m=m>0 and "-" or chk~="0" and ps and "+" or "" | |||
return ep>=s and (abt and "<abbr title=\""..m..n.."\">" or "")..m..nn..""..(not isinf and p.illion({args={math.floor(ep/3-1)}}) or "")..(abt and "</abbr>" or "") or m..n | |||
end | end | ||
end | end | ||
Line 76: | Line 79: | ||
if n>=math.huge then | if n>=math.huge then | ||
return math.huge | return math.huge | ||
elseif n> | elseif n>999 then | ||
i=10^(3*math.floor(math.log10(n)/3)) | i=10^(3*math.floor(math.log10(n)/3)) | ||
return (math.floor(n/i)>1 and p.illion({args={math.floor(n/i),false}}) or "")..(math.floor(math.log10(n)/3)<=#e3 and e3[math.floor(math.log10(n)/3)] or "["..math.floor(math.log10(n)/3).."]")..(r< | return (math.floor(n/i)>1 and p.illion({args={math.floor(n/i),false}}) or "")..(math.floor(math.log10(n)/3)<=#e3 and e3[math.floor(math.log10(n)/3)] or "["..math.floor(math.log10(n)/3).."]")..(r<3 and p.illion({args={n%i,nil,true,r+1}}) or "")..(r==3 and "..." or "") --it can only go so far down, this limit is to prevent not enough memory errors | ||
else | else | ||
return n<b0 and "" or (u00 and n<#e00) and e00[1+n] or e0[1+(n%10)]..e1[1+(math.floor(n/10)%10)]..e2[1+(math.floor(n/100)%10)] | return n<b0 and "" or (u00 and n<#e00) and e00[1+n] or e0[1+(n%10)]..e1[1+(math.floor(n/10)%10)]..e2[1+(math.floor(n/100)%10)] |