zoukankan      html  css  js  c++  java
  • Lua 之table库

    标准table库

    table是一个关联数组,其索引可以是数字或者字符串,例如:

    t = {1, 4, ['name']='sina', 5}
    t[3] = 6
    t['name'] = 'new'
    t.name = 'new'
    for k,v in pairs(t) do
        print(k, v)
    end

    table.concat(table, sep,  start, end)

    concat是concatenate(连锁, 连接)的缩写,table.concat()函数列出参数中指定table的数组部分从start位置到end位置的所有元素,元素间以指定的分隔符(sep)隔开。除了table外, 其他的参数都不是必须的, 分隔符的默认值是空字符,start的默认值是1,end的默认值是数组部分的总长。

    sep, start, end这三个参数是顺序读入的,所以虽然它们都不是必须参数,但如果要指定靠后的参数, 必须同时指定前面的参数.

    tbl = {"alpha", "beta", "gamma"}
    print(table.concat(tbl, ":"))
    -- alpha:beta:gamma
    print(table.concat(tbl, nil, 1, 2))
    --alphabeta
    print(table.concat(tbl, "
    ", 2, 3))
    --beta
    --gamma



    table.insert(table, pos, value)

    table.insert()函数在table的数组部分指定位置(pos)插入值为value的一个元素。 pos参数可选,默认为数组部分末尾.

    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()函数返回指定table中所有正数key值中最大的key值。 如果不存在key值为正数的元素,则返回0。此函数不限于table的数组部分。

    tbl = {[1] = "a", [2] = "b", [3] = "c", [26] = "z"}
    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中间删除一个元素,后面的元素的索引会依次往前减1,例如:

    a = {1,2,3,4,5,6,7}
    for k,v in pairs(a) do
        if k==4 then table.remove(a, k) end 
        print(k,'=',v)
    end


    table.sort(table, comp)

    table.sort()函数对给定的table进行升序排序.

    tbl = {"alpha", "beta", "gamma", "delta"}
    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, {
     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进行排序时,应用以下的规则:按等级升序排序,在等级相同时,按姓名升序排序。

    可以写出这样的排序函数:

    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常用的一个操作是按key的字典顺序遍历,但在table中,索引是一个无序的集合,如果要对他们进行排序,必须将它们复制到一个数组中,然后对这个数组进行排序。

    下面是一个使用迭代器实现对索引有序遍历的例子:

    lines = {
        name='xijinping',
        age=59,
        city='beijing',
    }   
    
    function parisByKeys(t)
    
        local a = {}
        for k in pairs(lines) do a[#a+1]=k end
        table.sort(a)
    
        local i = 0
    
        return function ()
            i = i+1
            return a[i], t[a[i]]
        end
    end 
    
    
    for k, v in parisByKeys(lines) do
        print(k,'	',v)
    end 

    table.foreachi(table, function(i, v))
    会期望一个从 1(数字 1)开始的连续整数范围,遍历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中元素的个数

    t1 = {1, 2, 3, 5};
    print(getn(t1))
    --4


    table.setn(table, nSize)

    设置table中的元素个数

  • 相关阅读:
    JAVA 桥接模式
    字模生成/提取原理
    const修饰指针
    BMP格式分析
    [转载]在.Net中使用SMTP发送邮件
    [转载]MD5加密解密
    四十二。java
    四十四。java
    四十一。复习第十二章内容
    三十六。文件流
  • 原文地址:https://www.cnblogs.com/chenny7/p/4024129.html
Copyright © 2011-2022 走看看