LUA IO库
最后更新于:2022-04-01 10:07:21
I/O库为文件操作提供两种模式。简单模式(simple model)拥有一个当前输入文件和一个当前输出文件,并且提供针对这些文件相关的操作。完全模式(complete model)使用外部的文件句柄来实现。
## 简单模式
I/O库将当前输入文件作为标准输入(stdin),将当前输出文件作为标准输出(stdout)。这样当我们执行io.read,就是在标准输入中读取一行。
写操作较读操作简单,我们先从写操作入手。
下面这个例子里函数io.write获取任意数目的字符串参数,接着将它们写到当前的输出文件。
~~~
local t = io.write("sin (3) = ", math.sin(3), "\n")
--> sin (3) = 0.1411200080598672
print("hello", "Lua"); print("Hi")
-->hello Lua
-->Hi
~~~
注:Write函数与print函数不同在于,write不附加任何额外的字符到输出中去,例如制表符,换行符等等。还有write函数是使用当前输出文件,而print始终使用标准输出。另外print函数会自动调用参数的tostring方法,所以可以显示出表(tables)函数(functions)和nil。
read函数:从当前输入文件读取串,由它的参数控制读取的内容:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-22_56cb2ca2ad621.jpg)
例子:
~~~
--io.read 从标准输入流中获得,默认设置下,就是你的屏幕输入
t = io.read("*all")
t = string.gsub(t, ...) -- do the job
io.write(t) -- write the
~~~
提示:若使用luaEditor编辑器,估计无法在屏幕输入。
## 完全模式
完全模式的核心在于文件句柄(file handle)。该结构类似于C语言中的文件流(FILE*),其呈现了一个打开的文件以及当前存取位置。打开一个文件的函数是io.open。它模仿C语言中的fopen函数,同样需要打开文件的文件名参数,打开模式的字符串参数:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-22_56cb2ca2bc20e.jpg)
例子:
~~~
--读操作
file = io.open("testRead.txt", "r")
for line in file:lines() do
print(line)
end
file:close()
--写操作
file = io.open("testRead.txt","a+")
file:write("\nhello")
file:close()
~~~
素材:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-22_56cb2ca2cc9ea.jpg)
内容:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-22_56cb2ca2dec7b.jpg)
运行结果:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-22_56cb2ca2ed7b8.jpg)
文件内容:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-22_56cb2ca30537e.jpg)