LuaTable、LuaArrayTable、LuaDictTable中数据的增删改查
- 介绍
- Lua表
-
- lua表初始化
- lua移除引用
- lua中向表中添加数据
- lua中表中移除数据
- lua表中连接数据
- lua表中数据排序
- 获取lua表长度
- 获取表中最大值
- UnityC#中LuaTable
- UnityC#中LuaArrayTable、LuaDictTable、LuaDictTable
介绍
在Lua中和C#中对lua的表进行增删改查是比较常用的表操作,这里主要对比一下lua和C#中分别怎么对表进行增删改查
Lua表
lua表初始化
- mytable = {}
lua移除引用
- mytable = nil
lua中向表中添加数据
-
向xxtable中的index位置插入一个xx数据 table.insert(xxtab,index,xx)
-
向xxtable中末尾位置插入一个xx数据 table.insert(xxtab,xx)
-
向xxtab总末尾位置加入一个yytab表数据table.insert(xxtab,yytab)
-
向xxtab中index位置值修改为xxx(没有值则相当于添加数据)xxtab[index] = xxx
lua中表中移除数据
- lua中移除表中的指定索引数据 table.remove(xxtab,index)
- lua中移除表中末尾数据 table.remove(xxtab)
lua表中连接数据
- lua连接数据 table.concat(xxtab) 比如{“a”,“b”,“c”,5,“d”} 输出string类型 “abc5d”
- 用x符号连接表中数据 table.concat(xxtab,“x”) 比如{“a”,“b”,“c”,5,“d”} 输出string类型 “axbxcx5xd”
- 用x符号连接表中2到4的数据 table.concat(xxtab,“x”,2,4) 比如{“a”,“b”,“c”,5,“d”} 输出string类型 “bxcx5”
lua表中数据排序
- lua表默认排序 table.sort(table)
- lua表自定义function(a,b)条件排序 table.sort (table, funtion(a,b))
获取lua表长度
- lua中获取表的长度 #table
获取表中最大值
- lua中获取xxtab表中的最大值 table.maxn(xxtab) 比如{1,2,3,4,7} 输出7
UnityC#中LuaTable
- 获取原表 LuaTable GetMetaTable()
- 转成LuaArrayTable LuaArrayTable ToArrayTable()
- 转成LuaDictTable LuaDictTable ToDictTable()
- 转成LuaDictTable LuaDictTable ToDictTable()
- 转成object[] object[] ToArray()
- 打印表内存地址 string ToString()
- 修改值和获取值
修改:tab[index] = xxx 或者 tab[“xxx”] = xxx
修改:table.SetTable(string,T)
修改:table.RawSet(K,V)
修改:RawSetIndex(int , T)
获取:T RawGetIndex(int)
获取:tab[index]或者tab[“xxx”]
获取:T table.GetTable(string)
获取:V table.RawGet(K)
lua表如下
修改和复制代码如下:
打印如下:
- 获取长服务器托管网度 tab.Length
- LuaTable中的func方法
获取方法 GetLuaFunction(“key”)
获取方法 RawGetLuaF服务器托管网unction(“key”)
执行方法无返回值无参数 func1.Call()
执行方法无返回值 func1.Call(T) 支持多参数这里不详细写了
执行方法有返回值无参数 R func1.Invoke()
执行方法有返回值有参数 R func1.Invoke(T) 支持多参数这里不详细写了
lua表如下:
代码如下:
打印如下:
UnityC#中LuaArrayTable、LuaDictTable、LuaDictTable
它们都继承自IEnumerable相当于 Array Dictionary List使用方式
遍历可用下面的方法
var itor = tab.GetEnumerator();
while (itor.MoveNext())
{
Debug.LogError("itor.Current.Key = " + itor.Current.Key + " ,itor.Current.Value = " + itor.Current.Value);
}
itor.Dispose();
还可以辅助LuaTable转换成对应的List和Dictionary
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
相关推荐: 2023.12.15 FineBI与kettle
1.结构化就是可以用schema描述的数据,就是结构化数据,能转为二维表格, 如CSV,Excel, 2.半结构化就是部分可以转换为二维表格,如JSON,XML 3.非结构化数据,就是完全无法用二维表格表示的数据,如Word文档,Mp4,图片,等文件. ket…