码云代码链接
https://gitee.com/wenwenc9/lua_pro.git
Lua I/O 库用于读取和处理文件。分为简单模式(和C一样)、完全模式。
- 简单模式(simple model)拥有一个当前输入文件和一个当前输出文件,并且提供针对这些文件相关的操作。
- 完全模式(complete model) 使用外部的文件句柄来实现。它以一种面对对象的形式,将所有的文件操作定义为文件句柄的方法
file = io.open (filename [, mode])
mode 的值有:
一、简单模式
-- 以只读方式打开文件
file = io.open("test.lua", "r")
print(file)
io.input(file) -- 设置默认输入文件为 test.lua
print(io.read()) -- 输出文件第一行
io.close(file)
-- 以附加的方式打开只写文件
file = io.open("test.lua", "a")
io.output(file) -- 设置默认输出文件为 test.lua
io.write("-- test.lua 文件末尾注释") -- 在文件最后一行添加 Lua 注释
io.close(file)
在以上实例中我们使用了 io.“x” 方法,其中 io.read() 中我们没有带参数,参数可以是下表中的一个:
其他的 io 方法有:
- io.tmpfile():返回一个临时文件句柄,该文件以更新模式打开,程序结束时自动删除
- io.type(file): 检测obj是否一个可用的文件句柄
- io.flush(): 向文件写入缓冲中的所有数据
- io.lines(optional file name): 返回一个迭代函数,每次调用将获得文件中的一行内容,当到文件尾时,将返回nil,但不关闭文件
二、完全模式
通常我们需要在同一时间处理多个文件。我们需要使用 file:function_name 来代替 io.function_name 方法。以下实例演示了如同同时处理同一个文件:
-- 读取
file = io.open('test.lua','r')
print(file:read('*a'))
file:close()
-- 追加
file = io.open("test.lua", "a")
file:write("--test")
file:close()
read 的参数与简单模式一致。
其他方法:
- file:seek(optional whence, optional offset): 设置和获取当前文件位置,成功则返回最终的文件位置(按字节),失败则返回nil加错误信息。参数 whence 值可以是:
"set": 从文件头开始
"cur": 从当前位置开始[默认]
"end": 从文件尾开始
offset:默认为0
不带参数file:seek()则返回当前位置,file:seek(“set”)则定位到文件头,file:seek(“end”)则定位到文件尾并返回文件大小
- file:flush(): 向文件写入缓冲中的所有数据
-
io.lines(optional file name): 打开指定的文件filename为读模式并返回一个迭代函数,每次调用将获得文件中的一行内容,当到文件尾时,将返回nil,并自动关闭文件。
若不带参数时io.lines() io.input():lines(); 读取默认输入设备的内容,但结束时不关闭文件,如
for line in io.lines("main.lua") do
print(line)
end
使用了 seek 方法,定位到文件倒数第 25 个位置并使用 read 方法的 *a 参数,即从当期位置(倒数第 25 个位置)读取整个文件。
-- 以只读方式打开文件
file = io.open("test.lua", "r")
file:seek("end",-25)
print(file:read("*a"))
-- 关闭打开的文件
file:close()
版权声明:本文为weixin_44238683原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。