Lua基础

Stella981
• 阅读 411
-- mac 上有很多文本编辑器,Himi找了很多,感觉TextMate是比较好用的,小巧且功能强大!而且免费,图标是个小菊花 - -

-- 注释语句

 

--[[  

注释段落语句

  ]]--

 

--引用其他lua文件,不需要加上(.lua)后缀

--require "xx"

 

--变量不需要定义,可以直接赋值

count = 100  --成员变量

local count =100  --局部变量

 

--方法定义

function hello(...)

    --打印

    print("Hello Lua!");

    print(string.format(...))

end

 

-- 每一行代码不需要使用分隔符,当然也可以加上

-- 访问没有初始化的变量,lua默认返回nil

 

-- 调用函数形式

hello("你懂的")

 

--打印变量的类型

isOK =false

print(type(isOK))

 

-- 基本变量类型

a =nil --Lua 中值为nil 相当于删除

b =10

c =10.4

d =false

--定义字符串,单引号,双引号都可以的

e ="i am"

d ='himi'

 

--两个字符串的连接可以如下形式

stringA ="Hi"

stringB ="mi"

print(stringA..stringB)

 

--另外Lua也支持转移字符,如下

print(stringA.."\n"..stringB);

 

--修改字符串的部分gsub,可以如下形式:(将stringA字符串中的Hi修改为WT)

stringA=string.gsub(stringA,"Hi","WT")

print(stringA);

 

--将字符换成数字tonumber(不转也会自动转)

--将数字换成字符tostring(不转也会自动转)

stringC = "100"

stringC = tonumber(stringC)

stringC = stringC +20

stringC = tostring(stringC)

print(stringC)

 

--取一个字符串的长度使用 #

print(#stringC)

 

--创建 表

tableA ={}

m = "x"

tableA[m] =100

m2 ='y'

tableA[m2] =200

print(tableA["x"].."\n"..tableA.y)

--另外表还可以如下形式(从1开始)

tableB ={"4","5","6","7","8"}

print(tableB[1])

 

--算术操作符

c1 = 10+2

c2 = 10-2

c3 = 10*2

c4 = 10/2

c5 = 10^2

c6 = 10%2

c7 = -10+2

print(c1.."_"..c2.."_"..c3.."_"..c4.."_"..c5.."_"..c6.."_"..c7)

 

--控制操作

--if then elseif then else end

abc =10

if  abc ==10 then

    print("v1")

elseif abc == 9 then

    print("v2")

else

    print("v3")

end

 

--for

--从4(第一个参数)涨到10(第二个参数),每次增长以2(第三个参数)为单位

for i=4,10,2 do

    print("for1:"..i+1)

end

--也可以不制定最后一个参数,默认1的增长速度

for i=4,10 do

    print("for2:"..i+1)

end

 

tableFor = {"himi1","himi2","himi3","himi4","himi5"}

for k,v in pairs(tableFor) do

    print("for3:key:"..k.."value:"..v)

end

 

--while

w1 = 20

while true do

    w1=w1+1

    if w1 ==25 then

        break

    end

end

print("whlile:"..w1)

 

--repeat

    aa =20

    repeat aa = aa+2

        print("repeat:"..aa)

    until aa>28

 

--关系操作符

--需要注意的是不等于符号 ~=  而不是!=

ax =10

bx =20

 

if ax >bx then

    print("GX1")

elseif ax<bx then

    print("GX2")

elseif ax>=bx then

    print("GX3")

elseif ax<=bx then

    print("GX4")

elseif ax==bx then

    print("GX5")

elseif ax~=bx then

    print("GX6")

else

    print("GX7")

end

其中主要需要注意的是,判断语句不等于,不再是!= ,在Lua中是~= 

,这个要注意。另外关于一些常见的函数如下详解:

--函数详解



--有一个返回值的函数

function funTestBackOne(aCount)

    local aCount= aCount+1

    return aCount

end

 

a =20

print(funTestBackOne(a))

 

--有多个返回值的函数

function funTestBackMore()

    return 2,3

end

 

a,b =funTestBackMore()

print(a.." and "..b)

 

--有变长参数的函数

function funTestUnKnow( ... )

    print(...)

end

funTestUnKnow(a,b,"Himi")

 

--闭合函数(一个函数写在另外一个函数内)

function funTest1( ... )

    local d = 12;

    d=d+...

    function funTest2( ... )

        print(d)

    end

    funTest2()

end

 

funTest1(100)

setmetatable 设置 table的元表,

 self.__index = self 设置查找失败后向上索引的 table 

 2者是实现继承的核心

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
2年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Easter79 Easter79
2年前
sql注入
反引号是个比较特别的字符,下面记录下怎么利用0x00SQL注入反引号可利用在分隔符及注释作用,不过使用范围只于表名、数据库名、字段名、起别名这些场景,下面具体说下1)表名payload:select\from\users\whereuser\_id1limit0,1;!(https://o
Stella981 Stella981
2年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
2年前
Bypass ngx_lua_waf SQL注入防御(多姿势)
0x00前言ngx\_lua\_waf是一款基于ngx\_lua的web应用防火墙,使用简单,高性能、轻量级。默认防御规则在wafconf目录中,摘录几条核心的SQL注入防御规则:select.(from|limit)(?:(union(.?)select))(?:from\Winformation_schema\W)这边
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
5个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这