<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # **table(表)** table 是 Lua 的一種數據結構用來幫助我們創建不同的數據類型,如:數組、字典等。 Lua table 使用關聯型數組,你可以用任意類型的值來作數組的索引,但這個值不能是 nil。 Lua table 是不固定大小的,你可以根據自己需要進行擴容。 Lua也是通過table來解決模塊(module)、包(package)和對象(Object)的。 例如string.format表示使用"format"來索引table string。 ## **Table 操作** 以下列出了 Table 操作常用的方法: | 序號 | 方法 & 用途 | | --- | --- | | 1 | **table.concat (table \[, sep \[, start \[, end\]\]\]):** table.concat()函數列出參數中指定table的數組部分從start位置到end位置的所有元素, 元素間以指定的分隔符(sep)隔開。| | 2 | **table.insert (table, \[pos,\] value):** 在table的數組部分指定位置(pos)插入值為value的一個元素. pos參數可選, 默認為數組部分末尾. | | 3 | **table.maxn (table):** 指定table中所有正數key值中最大的key值. 如果不存在key值為正數的元素, 則返回0。(**Lua5.2之后該方法已經不存在了,本文使用了自定義函數實現**)| | 4 | **table.remove (table \[, pos\]):** 返回table數組部分位于pos位置的元素. 其后的元素會被前移. pos參數可選, 默認為table長度, 即從最后一個元素刪起。 | | 5 | **table.sort (table \[, comp\]):** 對給定的table進行升序排序。 | ### **table.concat:table連接** ``` fruits = {"banana","orange","apple"} -- 返回 table 連接后的字符串 print("連接后的字符串 ",table.concat(fruits)) //bananaorangeapple -- 指定連接字符 print("連接后的字符串 ",table.concat(fruits,", ")) //banana, orange, apple -- 指定索引來連接 table print("連接后的字符串 ",table.concat(fruits,", ", 2,3)) //orange, apple ``` ### **table.insert 與 table.remove:插入和移除** ``` fruits = {"banana","orange","apple"} -- 在末尾插入 table.insert(fruits,"mango") print("索引為 4 的元素為 ",fruits[4]) //索引為 4 的元素為 mango -- 在索引為 2 的鍵處插入 table.insert(fruits,2,"grapes") print("索引為 2 的元素為 ",fruits[2]) //索引為 2 的元素為 grapes print("最后一個元素為 ",fruits[5]) //最后一個元素為 mango table.remove(fruits) print("移除后最后一個元素為 ",fruits[5]) //移除后最后一個元素為 nil ``` ### **table.sort:Table 排序** 以下實例演示了 sort() 方法的使用,用于對 Table 進行排序: 實例 ``` fruits = {"banana","orange","apple","grapes"} print("排序前") for k,v in ipairs(fruits) do print(k,v) end table.sort(fruits) print("排序后") for k,v in ipairs(fruits) do print(k,v) end ``` 自定義實現table最大值 ``` function table_maxn(t) local mn=nil; for k, v in pairs(t) do if(mn==nil) then mn=v end if mn < v then mn = v end end return mn end tbl = {[1] = 2, [2] = 6, [3] = 34, [26] =5} print("tbl 最大值:", table_maxn(tbl)) print("tbl 長度 ", #tbl) ``` 注意: 當我們獲取 table 的長度的時候無論是使用 # 還是 table.getn 其都會在索引中斷的地方停止計數,而導致無法正確取得 table 的長度。 可以使用以下方法來代替: ``` function table_leng(t) local leng=0 for k, v in pairs(t) do leng=leng+1 end return leng; end ```
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看