Lua 文件 I/O

Lua I/O 库用于读取和处理文件。

Lua I/O 库读写文件时分为 简单模式(和C一样)和 完全模式

  • 简单模式(simple model) 拥有一个当前输入文件和一个当前输出文件,并且提供针对这些文件相关的操作。 简单模式在做一些简单的文件操作时较为合适

  • 完全模式(complete model) 使用外部的文件句柄来实现。它以一种面对对象的形式,将所有的文件操作定义为文件句柄的方法

    在进行一些高级的文件操作的时候,简单模式就显得力不从心。例如同时读取多个文件这样的操作,使用完全模式则较为合适。

打开文件操作

可以使用 io.open 打开文件

io.open 语法格式如下

file = io.open (filename [, mode])

mode 的值可以是以下之一

模式 描述
r 以只读方式打开文件,该文件必须存在
w 打开只写文件
若文件存在则文件长度清为 0,即该文件内容会消失
若文件不存在则建立该文件
a 以附加的方式打开只写文件
若文件不存在,则会建立该文件
如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留
r+ 以可读写方式打开文件,该文件必须存在
w+ 打开可读写文件,若文件存在则文件长度清为 0,即该文件内容会消失。
若文件不存在则建立该文件
a+ 与a类似,但此文件可读可写
b 二进制模式,如果文件是二进制文件,可以加上b
+ 号表示对文件既可以读也可以写

简单模式

简单模式使用标准的 I/O 或使用一个当前输入文件和一个当前输出文件

假设存在 demo.txt 文件,内容如下

$ cat demo.txt 
Hello 简单教程
简单教程,简单编程

main.lua

-- !/usr/bin/lua
-- -*- encoding:utf-8 -*-
-- filename: main.lua
-- author: 简单教程(www.twle.cn)
-- Copyright © 2015-2065 www.twle.cn. All rights reserved.

-- 以只读方式打开文件
file = io.open("demo.txt", "r")

-- 设置默认输入文件为 demo.txt
io.input(file)

-- 输出文件第一行
print(io.read())

-- 关闭打开的文件
io.close(file)

-- 以附加的方式打开只写文件
file = io.open("demo.txt", "a")

-- 设置默认输出文件为 demo.txt
io.output(file)

-- 在文件最后一行添加 Lua 注释
io.write("\n--  demo.txt 文件末尾注释")

-- 关闭打开的文件
io.close(file)

运行以上范例,输出结果如下

$ lua main.lua
Hello 简单教程

此时 demo.txt 内容如下

$ cat demo.txt 
Hello 简单教程
简单教程,简单编程
--  demo.txt 文件末尾注释--

io.read 方法

在以上范例中我们使用 io.read 方法

io.read 方法语法格式如下

string io.read(mode)

mode 参数可以是下表之一

模式 描述
*n 读取一个数字并返回它
例如: file.read("*n")
*a 从当前位置读取整个文件
例如:file.read("*a")
*l(默认) 读取下一行,达到文件末尾 (EOF) 则返回 nil
例如:file.read("*l")
number 返回一个指定字符个数的字符串,或在 EOF 时返回 nil
例如:file.read(5)

Lua 语言 io 模块的其它的方法如下

  • io.tmpfile() 返回一个临时文件句柄,该文件以更新模式打开,程序结束时自动删除

  • io.type(file) 检测obj是否一个可用的文件句柄

  • io.flush() 向文件写入缓冲中的所有数据

  • io.lines(optional file name) 返回一个迭代函数,每次调用将获得文件中的一行内容,当到文件尾时,将返回nil,但不关闭文件

完全模式

如果需要在同一时间处理多个文件,可以使用 file:function_name 来代替 io.function_name 方法

file:function_name 系列函数的参数和 io.function 一致

-- !/usr/bin/lua
-- -*- encoding:utf-8 -*-
-- filename: main.lua
-- author: 简单教程(www.twle.cn)
-- Copyright © 2015-2065 www.twle.cn. All rights reserved.

-- 以只读方式打开文件
file = io.open("demo.txt", "r")

-- 输出文件第一行
print(file:read())

-- 关闭打开的文件
file:close()

-- 以附加的方式打开只写文件
file = io.open("demo.txt", "a")

-- 在文件最后一行添加 Lua 注释
file:write("\n--test")

-- 关闭打开的文件
file:close()

运行以上 Lua 脚本,输出结果如下

$ lua main.lua
Hello 简单教程

此时 demo.txt 内容如下

Hello 简单教程
简单教程,简单编程
--  demo.txt 文件末尾注释
--test

file 模块其它方法如下

  • 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 方法,定位到文件倒数第 18 个位置并使用 read 方法的 *a 参数,即从当期位置(倒数第 18 个位置)读取整个文件

-- !/usr/bin/lua
-- -*- encoding:utf-8 -*-
-- filename: main.lua
-- author: 简单教程(www.twle.cn)
-- Copyright © 2015-2065 www.twle.cn. All rights reserved.

-- 以只读方式打开文件
file = io.open("demo.txt", "r")

file:seek("end",-18)
print(file:read("*a"))

-- 关闭打开的文件
file:close()

运行以上 Lua 脚本,输出结果如下

$ lua main.lua
??尾注释
--test
关于   |   FAQ   |   我们的愿景   |   广告投放   |  博客

  简单教程,简单编程 - IT 入门首选站

Copyright © 2013-2022 简单教程 twle.cn All Rights Reserved.