此方法位数学计算方法,可能效率不是最好,但可以提供一个计算思想。
这里实现2-16进制的转换,此思想可以扩展到任意进制。
数学思想:
比如给给定一个十进制数字 20,我们要转成8进制,我们就反复除以8,把结果取证,如果大于8,对结果继续除,每次的余数按顺序排列下来。最好结果就是 结果|余数|余数|余数....。20 / 8 = 2 余数 4,2 不大于等于8,停止运算,转换成的8进制就是:24
-- 数字进制转换
---@param num number 十进制数字
---@param hex number 转换的目标进制数(2-16)
---@return string
function Common.Dec2Hex(num,hex)
if num == nil or type(num) ~= "number" then
return num
end
if hex == nil then
return num
end
local hexMap = {0,1,2,3,4,5,6,7,8,9,'A','B',"C",'D','E','F'}
local v = {}
local s = math.floor(num / hex)
local y = num % hex
table.insert(v,1,y)
while s >= hex do
y = s % hex
table.insert(v,1,y)
s = math.floor(s / hex)
end
table.insert(v,1,s)
local r = ""
for _,k in ipairs(v) do
r = r .. hexMap[k + 1]
end
return r
end