table.concat(table, sep,? start, end)
concat是concatenate(連鎖, 連接)的縮寫. table.concat()函數(shù)列出參數(shù)中指定table的數(shù)組部分從start位置到end位置的所有元素, 元素間以指定的分隔符(sep)隔開具被。除了table外, 其他的參數(shù)都不是必須的, 分隔符的默認值是空字符, start的默認值是1, end的默認值是數(shù)組部分的總長.
sep, start, end這三個參數(shù)是順序讀入的, 所以雖然它們都不是必須參數(shù), 但如果要指定靠后的參數(shù), 必須同時指定前面的參數(shù).
> tbl = {"alpha", "beta", "gamma"}
> print(table.concat(tbl, ":"))
alpha:beta:gamma
> print(table.concat(tbl, nil, 1, 2))
alphabeta
> print(table.concat(tbl, "\n", 2, 3))
beta
gamma
table.insert(table, pos, value)
table.insert()函數(shù)在table的數(shù)組部分指定位置(pos)插入值為value的一個元素. pos參數(shù)可選, 默認為數(shù)組部分末尾.
> tbl = {"alpha", "beta", "gamma"}
> table.insert(tbl, "delta")
> table.insert(tbl, "epsilon")
> print(table.concat(tbl, ", ")
alpha, beta, gamma, delta, epsilon
> table.insert(tbl, 3, "zeta")
> print(table.concat(tbl, ", ")
alpha, beta, zeta, gamma, delta, epsilon
table.maxn(table)
table.maxn()函數(shù)返回指定table中所有正數(shù)key值中最大的key值. 如果不存在key值為正數(shù)的元素, 則返回0.此函數(shù)不限于table的數(shù)組部分.
> tbl = {[1] = "a", [2] = "b", [3] = "c", [26] = "z"}
> print(#tbl)
3?????????????? -- 因為26和之前的數(shù)字不連續(xù), 所以不算在數(shù)組部分內
> print(table.maxn(tbl))
26
> tbl[91.32] = true
> print(table.maxn(tbl))
91.32
table.remove(table, pos)
table.remove()函數(shù)刪除并返回table數(shù)組部分位于pos位置的元素. 其后的元素會被前移. pos參數(shù)可選, 默認為table長度, 即從最后一個元素刪起.
table.sort(table, comp)
table.sort()函數(shù)對給定的table進行升序排序.
> tbl = {"alpha", "beta", "gamma", "delta"}
> table.sort(tbl)
> print(table.concat(tbl, ", "))
alpha, beta, delta, gamma
comp是一個可選的參數(shù), 此參數(shù)是一個外部函數(shù), 可以用來自定義sort函數(shù)的排序標準.
此函數(shù)應滿足以下條件: 接受兩個參數(shù)(依次為a, b), 并返回一個布爾型的值, 當a應該排在b前面時, 返回true, 反之返回false.
例如, 當我們需要降序排序時, 可以這樣寫:
> sortFunc = function(a, b) return b < a end
> table.sort(tbl, sortFunc)
> print(table.concat(tbl, ", "))
gamma, delta, beta, alpha
用類似的原理還可以寫出更加復雜的排序函數(shù). 例如, 有一個table存有工會三名成員的姓名及等級信息:
guild = {}
table.insert(guild, {
name = "Cladhaire",
class = "Rogue",
level = 70,
})
table.insert(guild, {
name = "Sagart",
class = "Priest",
level = 70,
})
table.insert(guild, {
name = "Mallaithe",
class = "Warlock",
level = 40,
})
對這個table進行排序時, 應用以下的規(guī)則: 按等級升序排序, 在等級相同時, 按姓名升序排序.
可以寫出這樣的排序函數(shù):
function sortLevelNameAsc(a, b)
if a.level == b.level then
return a.name < b.name
else
return a.level < b.level
end
end
測試功能如下:
> table.sort(guild, sortLevelNameAsc)
> for idx, value in ipairs(guild) do print(idx, value.name) end
1, Mallaithe
2, Cladhaire
3, Sagart
table.foreachi(table, function(i, v))
會期望一個從 1(數(shù)字 1)開始的連續(xù)整數(shù)范圍哩簿,遍歷table中的key和value逐對進行function(i, v)操作
t1 = {2, 4, 6, language="Lua", version="5", 8, 10, 12, web="hello lua"};
table.foreachi(t1, function(i, v) print (i, v) end)?; --等價于foreachi(t1, print)
輸出結果:
1?2
2?4
3?6
4?8
5?10
6?12
table.foreach(table, function(i, v))
與foreachi不同的是忿等,foreach會對整個表進行迭代
t1 = {2, 4, 6, language="Lua", version="5", 8, 10, 12, web="hello lua"};
table.foreach(t1, function(i, v) print (i, v) end)?;
輸出結果:
1?2
2?4
3?6
4?8
5?10
6?12
web?hello lua
language?Lua
version?5
table.getn(table)
返回table中元素的個數(shù)
t1 = {1, 2, 3, 5};
print(getn(t1))
->4
table.setn(table, nSize)
設置table中的元素個數(shù)
local function sort( a, b )
? ? ? ? return a.wOrder < b.wOrder
end
table.sort( tab, sort )
-- 對 類型 wOrder 進行排序