数学库:

  三角函数:math.sin, math.cos, math.tan, math.asin, math.acos 都以弧度为单位;

  指数和对数函数:exp, log, log10;

  取整函数:math.floor, math.ceil;

  最大最小函数:math.max math.min;

  随机函数:math.randomseed, math.random(无参数返回[0,1),有参数返回[1,n])

  常量:math.pi, math.huge

table库:

  table.insert(t, v): 在数组末尾插入v;

  table.insert(t, i, v): 在数组指定位置插入v;

  table.remove(t): 从数组末尾删除元素;

  table.remove(t, i): 从数组指定位置删除元素;

  table.sort(t, func): 对数组进行排序,默认使用小于排序。func传入的是两个比较的数组元素,如果希望第一个在第二个之前,返回true,反之返回false;

  table.concat(t, split): 连接数组中的元素,返回一个字符串,split是分隔符;

字符串库:

  string.upper和string.lower: 大小写转换;

  string.sub(s, i, j): 提取s中从i到j位置的字符,如果索引是负数,那么就从字符串结尾开始倒数,-2代表倒数第二个字符;

  string.char(n): 将一个整数或多个整数转换成字符,并连接它们为一个字符串返回;

  string.byte(str, i, j): 返回str从i到j位置的字符的asc码

  string.format(str, ...): 格式化字符串;

  string.find(str, substr, i): 从i位置开始,在str找到substr的开始位置和结束位置;

  string.match(str, substr, i): 和find类似,只是返回值是找到的子串,主要用于模式匹配;

  string.gsbu(str, substr, newstr, n): 在str中找到所有子串,并用newstr替换,n如果指定就会限制替换次数。返回替换后的字符串和替换次数;

  string.gmatch(str, substr): 返回一个迭代器函数,可在for in中使用,每次迭代返回一个匹配到的子串;

  

模式匹配:

  %a: 匹配字母

  %d: 匹配数字

  %l: 小写字母

  %u: 大写字母

  %w:字母和数字

  %s:空白字符

  %p: 标点符号

  %c: 控制字符

  %x: 十六进制

   %b: 匹配配对字符,%b() %b[]等

  +: 匹配1个或多个

  *: 匹配0个或多个,贪婪匹配

  -: 匹配0个或多个,非贪婪匹配

  ?: 匹配0个或1个

  ^: 以某个模式开头进行匹配

  $: 以某个模式结束进行匹配

  []: 自定义匹配字符

匹配整数:string.find(str, "[+-]?%d+")

匹配注释:string.find(str, "/%*.-%*/")

  (): 捕获模式匹配中的一部分子串

    local s = "today is \"7/10/2012\""

    print(string.find(s, "(\")(%d+/%d+/%d+)(%1)")) // 10 20 " 7/10/2012 "

替换:

  string.gsub的第三个参数可以是:

    一个替换字符串;

    一个函数:会在每次找到匹配的时候调用该函数,函数参数是匹配到的子串,返回值是替换字符串,如果返回nil表示不进行替换;

    一个table:会在每次找到匹配的时候,用匹配到的子串作key,在table中寻找value,如果有就替换,没有就不进行替换;

解析url编码

function unescape (url)
url = string.gsub(url, "+", " ")
url = string.gsub(url, "%%(%x%x)", function (substr)
print(substr)
return string.char(tonumber(substr, ))
end)
return url
end function escape (url)
url = string.gsub(url, "[&=+%%%c]", function (c)
return string.format("%%%02x", string.byte(c))
end)
url = string.gsub(url, " ", "+")
return url
end

lua 基础库的更多相关文章

  1. Lua基础 函数(一)

    转自: http://blog.csdn.net/wzzfeitian/article/details/8653101 在Lua中,函数是对语句和表达式进行抽象的主要方法.既可以用来处理一些特殊的工作 ...

  2. Lua 学习之基础篇五<Lua OS 库>

    lua os库提供了简单的跟操作系统有关的功能 1.os.clock() 返回程序所运行使用的时间 local nowTime = os.clock() print("now time is ...

  3. Lua字符串库(整理)

    Lua字符串库小集 1. 基础字符串函数:    字符串库中有一些函数非常简单,如:    1). string.len(s) 返回字符串s的长度:    2). string.rep(s,n) 返回 ...

  4. cocos2d-x开发:服务端基础库封装

    元旦前面几天都在忙着面试,随后的几天也就一直在做服务端基础库开发方面的工作.对于服务端开发,是很久之前的事情了.那时候我还在大学读书,一直都是在倒腾服务端开发方面的东西,毕业后参加公司工作就是一直从事 ...

  5. Step By Step(Lua字符串库)

    Step By Step(Lua字符串库) 1. 基础字符串函数:    字符串库中有一些函数非常简单,如:    1). string.len(s) 返回字符串s的长度:    2). string ...

  6. Step By Step(Lua基础知识)

    Step By Step(Lua基础知识) 一.基础知识:    1. 第一个程序和函数:    在目前这个学习阶段,运行Lua程序最好的方式就是通过Lua自带的解释器程序,如:    /> l ...

  7. F#之旅5 - 小实践之下载网页(爬虫基础库)

    参考文章:https://swlaschin.gitbooks.io/fsharpforfunandprofit/content/posts/fvsc-download.html 参考的文章教了我们如 ...

  8. Lua 基础

    Lua 5.3 的中文手册, http://cloudwu.github.io/lua53doc 在线浏览 --第一部分 -- 两个横线开始单行的注释 --[[ 加上两个[和]表示 多行的注释. -- ...

  9. Lua标准库- 模块(Modules)

    Lua包库为lua提供简易的加载及创建模块的方法,由require.module方法及package表组成 1.module (name [, ···]) 功能:建立一个模块. module的处理流程 ...

随机推荐

  1. fifo read

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <sys/types. ...

  2. HDFS中的checkpoint( 检查点 )的问题

    1.问题的描述 由于某种原因,需要在原来已经部署了Cloudera CDH集群上重新部署,重新部署之后,启动集群,由于Cloudera Manager 会默认设置dfs.namenode.checkp ...

  3. poj3268 最短路

    //Accepted 1124 KB 0 ms #include <cstdio> #include <cstring> #include <iostream> # ...

  4. 11-10 CC150第一章

    题目: 1.1 Implement an algorithm to determine if a string has all unique characters. What if you can n ...

  5. 通过j-interop访问WMI实例代码

    代码: import java.net.UnknownHostException; import java.util.logging.Level; import org.jinterop.dcom.c ...

  6. PCL中point cloud的数据类型

    出处: http://wiki.ros.org/pcl/Overview 1.数据类型 1.1 ROS中point cloud数据类型 sensor mesgs::PointCloud sensor ...

  7. Bubble Sort_树状数组

    Problem Description P is a permutation of the integers from 1 to N(index starting from 1).Here is th ...

  8. IOS网络开发(二)

    1 局域网群聊软件 1.1 问题 UDP协议将独立的数据包从一台计算机传输到另外一台计算机,但是并不保证接受方能够接收到该数据包,也不保证接收方所接收到的数据和发送方所发送的数据在内容和顺序上是完全一 ...

  9. 十分钟了解分布式计算:GraphLab

    GraphLab是一个面向大规模机器学习/图计算的分布式内存计算框架,由CMU在2009年开始的一个C++项目,这里的内容是基于论文 Low, Yucheng, et al. "Distri ...

  10. border-image(转载)

    本文转自:http://www.zhangxinxu.com/wordpress/2010/01/css3-border-image%E8%AF%A6%E8%A7%A3%E3%80%81%E5%BA% ...