一部分的table函式只對其陣列部分產生影響, 而另一部分則對整個table均產生影響. 下面會分開說明.
table.concat(table, sep, start, end)
concat是concatenate(連鎖, 連線)的縮寫. table.concat()函式列出引數中指定table的陣列部分從start位置到end位置的所有元素, 元素間以指定的分隔符(sep)隔開。除了table外, 其他的引數都不是必須的, 分隔符的預設值是空字元, start的預設值是1, end的預設值是陣列部分的總長.sep, start, end這三個引數是順序讀入的, 所以雖然它們都不是必須引數, 但如果要指定靠後的引數, 必須同時指定前面的引數.
> tbl => 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()函式在table的陣列部分指定位置(pos)插入值為value的乙個元素. pos引數可選, 預設為陣列部分末尾.
> tbl => 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()函式返回指定table中所有正數key值中最大的key值. 如果不存在key值為正數的元素, 則返回0. 此函式不限於table的陣列部分.
> tbl => print(#tbl)3--
因為26和之前的數字不連續, 所以不算在陣列部分內
> print(table.maxn
(tbl))
26> tbl[91.32] = true
> print(table.maxn
(tbl))
91.32
table.remove(table, pos)
table.remove()函式刪除並返回table陣列部分位於pos位置的元素. 其後的元素會被前移. pos引數可選, 預設為table長度, 即從最後乙個元素刪起.
table.sort(table, comp)
table.sort()函式對給定的table進行公升序排序.
> tbl => table.sort
(tbl)
> print(table.concat(tbl, ", "
))alpha, beta, delta, gamma
comp是乙個可選的引數, 此引數是乙個外部函式, 可以用來自定義sort函式的排序標準.
此函式應滿足以下條件: 接受兩個引數(依次為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
用類似的原理還可以寫出更加複雜的排序函式. 例如, 有乙個table存有工會三名成員的姓名及等級資訊:
guild ={}table.insert
(guild, )
table.insert
(guild, )
table.insert
(guild, )
對這個table進行排序時, 應用以下的規則: 按等級公升序排序, 在等級相同時, 按姓名公升序排序.
可以寫出這樣的排序函式:
functionsortlevelnameasc(a, b)
if a.level == b.level then
return a.name else
return a.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(數字 1)開始的連續整數範圍,遍歷table中的key和value逐對進行function(i, v)操作
t1 = ;table.foreachi(t1,
function(i, v) print (i, v) end) ; --
等價於foreachi(t1, print)
輸出結果:
1224364
85106
12
table.foreach(table, function(i, v))
與foreachi不同的是,foreach會對整個表進行迭代
t1 = ;table.foreach(t1,
function(i, v) print (i, v) end) ;
輸出結果:
1224364
85106
12web hello lua
language lua
version
5
table.getn(table)
返回table中元素的個數
t1 = ;(getn(t1))
->4
table.setn(table, nsize)
設定table中的元素個數
函式庫檔案
乙個很簡單的問題除錯了好久,不過還算有收穫。現總結一下 1.vs2008中 math.h 標頭檔案中沒有定義m pi,如果程式確實要用m pi則需自己定義。define m pi 3.14159265358979323846 2.如果程式中自己定義的函式比較多,為了除錯方便使用方便,可以將這些函式都...
標準函式庫
1 rand與srand函式產生偽隨機數 cpp view plain copy print?intrand void void srand unsigned intseed rand返回乙個範圍在0和rand max之間的偽隨機數,為了避免程式每次執行時獲得相同的隨機數序列,可以使用srand函式...
tf 函式庫與np 函式庫的轉換
前言 在對演算法模型進行部署的時候,往往需要做一些工作。以xilinx開發板部署tf框架模型為例,首先需要對訓練好的ckpt模型進行freeze得到.pb模型,之後,對其進行量化 編譯生成elf檔案,然後在板卡上通過main.cc函式呼叫pb模型的輸入 輸出節點對網路模型進行計算,注意這裡的計算分為...