当前位置: 首页 > news >正文

Lua学习笔记:库函数

本文更新于2026-06-04,使用Lua 5.5.0。

目录
  • 基础函数
    • asset
    • ipairs
    • next
    • pairs
    • print
    • tostring
    • type
  • coroutine
    • coroutine.create
    • coroutine.resume
    • coroutine.wrap
    • coroutine.yield
  • io
    • io.close
    • io.flush
    • io.input
    • io.lines
    • io.open
    • io.output
    • io.popen
    • io.read
    • io.tmpfile
    • io.type
    • io.write
    • FILE:close
    • FILE:flush
    • FILE:lines
    • FILE:read
    • FILE:seek
    • FILE:setvbuf
    • FILE:write
  • os
    • os.date
  • string
    • string.byte
    • string.char
    • string.dump
    • string.find
    • string.format
    • string.gmatch
    • string.gsub
    • string.len
    • string.lower
    • string.match
    • string.rep
    • string.reverse
    • string.sub
    • string.upper
  • table
    • table.concat
    • table.insert
    • table.move
    • table.pack
    • table.remove
    • table.sort
    • table.unpack

官方文档:https://www.lua.org/manual/5.5/

基础函数

asset

断言。不为真则终止后续执行。

asset(BOOL <, MESSAGE>)

ipairs

用于遍历表(数组形式)。

for i, v in ipairs(TABLE) do
end

实际返回:next, TABLE, 0。

next

用于遍历表。

local NEXTINDEX, NEXTVALUE = next(TABLE <, INDEX>)

pairs

用于遍历表(哈希表形式)。

for k, v in pairs(TABLE) do
end

实际返回:next, TABLE, nil。

print

打印。

print(<VALUE<, ...>>)

tostring

转换成字符串。

local STR = tostring(VALUE)

type

返回数据类型。

local STR = type(VALUE)

coroutine

coroutine.create

创建协程。不会启动协程。

local COROUTINE = coroutine.create(FUNCTION)

coroutine.resume

恢复执行协程。

local STATUS, RETURNVALUE<, ...>|YIELDVALUE<, ...>|FAIL = coroutine.resume(COROUTINE <, RESUMEVALUE<, ...>>)

第一次执行时,RESUMEVALUE作为coroutine.create的FUNCTION的参数传入。后续执行时,RESUMEVALUE作为coroutine.yield的返回值。

当协程正常退出或让出时,返回true及退出或让出时的返回值;当协程非正常退出时,返回false和错误信息。

coroutine.wrap

创建协程,返回包装函数。

local WRAPFUNCTION = coroutine.wrap(FUNCTION)

WRAPFUNCTION类似coroutine.resume,但参数只包括RESUMEVALUE,返回值只包括RETURNVALUE|YIELDVALUE。

coroutine.yield

暂停协程,让出执行权。

local RESUMEVALUE<, ...> = coroutine.yield(<YIELDVALUE <, ...>>)

io

API有两种风格:一种是基于文件句柄(io.METHOD),另一种是基于当前操作的文件(FILE:METHOD)。

io.close

关闭文件。

io.close(<FILE>)

如不指定FILE,则关闭默认输出文件。

等同于file:close()

io.flush

将程序中的缓冲区数据刷新至文件。

io.flush()

等同于io.output():flush()

io.input

设置默认输入文件。

io.input(<FILE|FILENAME>)

io.lines

以只读模式打开文件,返回迭代器函数。

local FUNCTION = io.lines(<FILENAME <, ...>>)

每次调用迭代器函数都会从文件返回一行。当泛型for循环结束时,会自动关闭文件。

io.open

打开文件。

local FILE <, FAIL> = io.open(FILE <, MODE>)

如打开失败,则返回nil。

io.output

设置默认输出文件。

io.output(<FILE|FILENAME>)

io.popen

运行外部进程,并返回从此进程读写的文件句柄。

local FILE = io.popen(PROGRAM <, MODE>)

MODE可为:

  • a:追加。
  • r:只读。
  • w:只写。会清空文件。
  • a+:读写追加。
  • r+:读写。不清空文件,但会写覆盖。
  • w+:读写。会清空文件。

io.read

从文件读取内容。

local STR = io.read(<FORMAT>)

FORMAT可为:

  • a:读取余下所有内容。
  • l:读取一行,不包括换行符。默认值。
  • L:读取一行,包括换行符。
  • n:读取一个数值。
  • 整数:读取若干字节。

等同于io.input().read(<FORMAT>)

io.tmpfile

返回可读写的临时文件。进程结束时会被自动删除。

local FILE = io.tmpfile()

io.type

返回文件的状态类型。

var STR = io.type(FILE)

返回值可为:

  • closed file:关闭的文件。
  • file:打开的文件。
  • nil:文件句柄不存在。

io.write

写入文件。

io.write(<STR|NUMBER <, ...>>)

FILE:close

关闭文件。

FILE:close()

FILE:flush

将缓冲区数据刷新至文件。

FILE:flush()

FILE:lines

以只读模式打开文件,返回迭代器函数。

local FUNCTION = FILE:lines(<FILENAME <, ...>>)

每次调用迭代器函数都会从文件返回一行。当泛型for循环结束时,不会自动关闭文件。

FILE:read

从文件读取内容。

local STR = FILE.read(<FORMAT>)

FORMAT可为:

  • a:读取余下所有内容。
  • l:读取一行,不包括换行符。默认值。
  • L:读取一行,包括换行符。
  • n:读取一个数值。
  • 整数:读取若干字节。

FILE:seek

设置和获取当前文件位置。

location POSITION = FILE:seek(<WHENCE <, OFFSET>>)

WHENCE可为:

  • cur:当前位置。
  • end:文件结尾。
  • cur:文件开头。

FILE:setvbuf

设置输出文件的缓存模式。

FILE:setvbuf(MODE <,SIZE>)

MODE可为;

  • full:全缓存,缓存满后才输出。
  • line:行缓存,以行为单位输出。
  • no:无缓存,直接输出。

FILE:write

写入文件。

FILE:write(<STR|NUMBER <, ...>>)

os

os.date

格式化时间。

local STR = os.date(FORMAT <, TIME>)

FORMAT使用"%"开头的格式化字符串。

string

也可以使用STRING:METHOD的面向对象形式。

string.byte

返回字符串的ASCII码。

local ASCII<, ...> = string.byte(STR <, START <, END>>)

START默认为1,END默认为START。

string.char

使用ASCII码组装字符串。

local STR = string.char(ASCII<, ...>)

string.dump

将函数序列化为二进制字符串。

local STR = string.dump(FUNCTION <, STRIP>)

如果STRIP为true,则不会包含所有调试信息,以节省空间。

string.find

查找子串。

local START, END = string.find(STR, PATTERN <, OFFSET <, PLAIN>>)

OFFSET为负数表示从结尾数起的偏移(含)。默认为1。

PLAIN为true则为纯文本匹配。默认为false。

string.format

格式化字符串。

local STR = string.format(FORMAT <, VALUE<, ...>>)

string.gmatch

全局匹配。返回一个迭代器,用来遍历所有匹配的值。

for VALUE<, ...> in string.gmatch(STR, PATTERN) do
end

string.gsub

全局替换。

local NEWSTR, COUNT = string.gsub(STR, PATTERN, VALUE <, LIMIT>)

string.len

字符串长度。

local N = string.len(STR)

string.lower

小写字符串。

local NEWSTR = string.lower(STR)

string.match

匹配子串。

local SUBSTR = string.match(STR, PATTERN <, OFFSET>)

OFFSET为负数表示从结尾数起的偏移(含)。默认为1。

string.rep

重复字符串。

local NEWSTR = string.rep(STR, N <, SEPARATOR>)

string.reverse

翻转字符串。

local NEWSTR = string.reverse(STR)

string.sub

字符串子串。

local SUBSTR = string.sub(STR, START <, END>)

START和END如指定,均包含此元素。START默认为1,END默认为-1。

string.upper

大写字符串。

local NEWSTR = string.upper(STR)

table

table.concat

拼接数组元素。拼接是元素必需为数字或字符串。

local STR = table.concat(TABLE <, SEPARATOR <, START <, END>>>)

START和END如指定,均包含此元素。

table.insert

向数组中插入元素。

table.insert(TABLE <, INDEX>, VALUE)

VALUE插入于INDEX索引。如不指定INDEX,则于末尾插入。

table.move

复制数组元素。

table.move(TABLE, START, END, INDEX <, OTHERTABLE>)

将下标区间[START, END]的数组元素复制至INDEX索引。如不指定OTHERTABLE,则为TABLE自身。

table.pack

将表打包至新表。新表的索引1为原表的拷贝,属性n为原表的大小。

local NEWTABLE = table.pack(TABLE)

table.remove

从数组中移除并返回一个元素。

local VALUE = table.remove(TABLE <, INDEX>)

如不指定INDEX,默认为末尾的元素。

table.sort

数组排序。

table.sort(TABLE <, COMPAREFUNCTION>)

table.unpack

拆解数组。

local VALUE<, ...> = table.unpack(TABLE <, START <, END>>)
http://www.jsqmd.com/news/950932/

相关文章:

  • HR总监紧急通知:下季度起所有请假系统必须通过ISO/IEC 23894 AI治理认证,你准备好了吗?
  • PyWxDump终极指南:如何安全解密微信聊天记录与数据备份
  • 实时盯盘+自动再平衡+税务优化——仅用Python+FinBERT+本地LLM,打造你的离线AI理财管家(开源代码已脱敏上线)
  • Kimi K2.6 AI Agent实战解析:任务拆解、工具调用与自主反思
  • 2026年常州合同纠纷律师避坑指南:5位专业可靠律师推荐 - 本地品牌推荐
  • 2026年POLO衫/男士短袖纯棉POLO衫/工作服品牌TOP榜单:版型挺括与舒适透气之选 - 品牌企业推荐师(官方)
  • 无人机组装线多机型共线落地实测 柔性生产可行性科普
  • iOS开发避坑指南:手把手教你搞定Xcode里的entitlements文件配置(附常见权限列表)
  • AI时代,网络安全该怎么做?Fortinet给出一种思路
  • 镜像智联,视频孪生新高度
  • 创意拉满!用 AI 打造图文、短视频一站式内容
  • 证书过期告警失效?用这7行Python+LangChain代码,让AI自动预测、续签、审计全链路
  • 你的Java应用正在‘堵车’:深入理解Oracle行锁竞争(enq:TX)对程序性能的隐形伤害
  • 2026年炸鸡加盟品牌推荐榜单:韩式炸鸡/炸鸡外卖/小成本创业/网红脆皮炸鸡店实力解析与口碑之选 - 品牌企业推荐师(官方)
  • MATLAB随机森林工具包:含分类/回归主函数、示例数据、Fortran加速DLL及可视化支持
  • Vulkan Dynamic Uniform Buffers 详解:从普通 UBO 到动态偏移的工程实践
  • 从传感器到屏幕:一文搞懂RAW、RGB、YUV(YCrCb)的区别与应用场景
  • AI搜索优化如何赋能杭州企业?杭州爱搜索深度解析GEO实战路径 - 品牌报告
  • AI工具如何重构KPI体系:从数据采集、实时反馈到自动校准的闭环实践(HRBP亲测有效)
  • 公路桥梁车桥耦合仿真工具集:MATLAB驱动ANSYS建模、随机车流生成与桥面不平度模拟
  • VC6.0平台可直接运行的亚像素边缘检测工具:含源码、测试图与双编译版本
  • 终极LRC歌词制作指南:零基础快速上手歌词滚动姬
  • CentOS服务器运维笔记:为Tesla K80等老显卡配置稳定的CUDA深度学习环境
  • 小米穿戴设备个性化表盘制作终极指南:零基础打造专属智能手表界面
  • 论智慧的本质属性与伪智慧批判——基于先验绝对真理标准的哲学清算
  • 什么是大模型?
  • SuperPNG终极指南:如何用免费插件彻底优化Photoshop PNG导出
  • 销售易开发者技能包上线丨0代码开发新能力,业务更满意
  • 耗时两月整理|史上最全网络安全挖洞平台汇总:大厂 SRC + 政企专项 + 国外赏金平台分级清单,小白入门永久珍藏指南
  • 采购管理的数字化怎么才不走过场?