一、前言:
lua 的制表符还是不够强大,当某一行特别大的时候,后面就全乱套了。这语言又不像python一样有这丰富的库可以调用。没办法,手写一个吧。
二、代码如下:
逻辑很简单,就是先遍历一遍数据,记录每一列的最大长度。
然后根据 当前列最大长度 - 具体的数据长度 获得需要填充空格即可;
-- 将二维数组以左对齐的形式拼接成字符串并返回
function leftAlignString(data)
local data2 = {}
local colLenList ={}
local len, vlen = #data[1]
for i, v in ipairs(data) do
data2[i] = {}
for vi, vd in ipairs(v) do
if type(vd) ~= "string" then
vd = tostring(vd)
end
data2[i][#data2[i] + 1] = vd
if vi ~= len then
data2[i][#data2[i] + 1] = ""
-- if i == 1then
-- colLenList[vi] = math.max(colLenList[vi] or 0, #vd / 3 * 2 + 4)
-- else
-- if #vd % 2 == 1 then
-- vlen = #vd + 1
-- else
vlen = #vd
-- end
colLenList[vi] = math.max(colLenList[vi] or 0, vlen + 2)
-- end
else
data2[i][#data2[i] + 1] = "\n"
end
end
end
-- 填充空格
function bEmpty(count)
local str = ""
local fourEmpty = " ";
while count > 0 do
if count >= 4 then
str = str .. fourEmpty
count = count - 4
else
str = str .. " "
count = count - 1
end
end
return str
end
local empty = 0
for i, v in ipairs(data2) do
for k = 1, (len - 1) * 2 - 1, 2 do
-- if i == 1 then
-- -- print(v[k], k, colLenList[math.ceil(k / 2)], #v[k] / 3 * 2)
-- data2[i][k + 1] = bEmpty(colLenList[math.ceil(k / 2)] - #v[k] / 3 * 2)
-- else
-- print(v[k], k, colLenList[math.ceil(k / 2)], #v[k])
data2[i][k + 1] = bEmpty(colLenList[math.ceil(k / 2)] - #v[k])
-- end
end
data2[i] = table.concat(v)
end
return table.concat(data2)
end
local data = {
{"index", "itemID", "randValue", "changeWeight", "initWeight", "isCompenate", "compenateData"},
{1,52301,357229,1000000,1000000,false,"{}"},
{1,52301,357229,1000000,1044400000,false,"{}"},
{1,52301,357229,100000440,1000000,false,"{}"},
{1,52301,357444229,1000000,1000000,false,"{}"},
{2,51302,502332,26000,1875, false, "{}"},
}
data2 = leftAlignString(data)
print(data2)
三、结尾
逻辑很简单,就是写的时候费了点时间。需要的直接拿来用就可以了
这个方法如果是对齐中文还是会有些偏差,代码里面的注释是稍微修正偏差的方法,取消注释就可以用。