博客
关于我
(Lua 笔记):Lua 文件 I/O
阅读量:364 次
发布时间:2019-03-04

本文共 1368 字,大约阅读时间需要 4 分钟。

Lua 文件 I/O

目录

  • 简单模式(simple model)
  • 完全模式(complete model)
  • 读取文件操作
  • 写入文件操作
  • 文件操作方法
  • 文件句柄操作
  • 临时文件操作
  • 其他文件操作方法

Lua 文件 I/O

Lua 提供了强大的文件操作功能,主要通过 io 库实现。以下是关于 Lua 文件 I/O 的详细说明。


简单模式(simple model)

简单模式是最常用的文件操作模式,适用于大多数基本文件操作需求。它使用 io 库中的标准方法来处理文件。

读取文件操作

-- 以只读方式打开文件file = io.open("test.lua", "r")-- 设置默认输入文件为 test.luaio.input(file)-- 输出文件第一行print(io.read())-- 关闭打开的文件io.close(file)

写入文件操作

-- 以附加的方式打开只写文件file = io.open("test.lua", "a")-- 设置默认输出文件为 test.luaio.output(file)-- 在文件最后一行添加 Lua 注释io.write("-- test.lua 文件末尾注释")-- 关闭打开的文件io.close(file)

io 方法

  • io.read():用于读取文件内容,支持多种模式,如 *n*a*l 等。
  • 其他常用方法:io.tmpfile()io.type(file)io.flush()io.lines() 等。

完全模式(complete model)

完全模式通过文件句柄的方法实现文件操作,更适合高级文件操作需求。以下是完全模式的使用示例:

读取文件操作

-- 以只读方式打开文件file = io.open("test.lua", "r")-- 输出文件第一行print(file:read())-- 关闭打开的文件file:close()

写入文件操作

-- 以附加的方式打开只写文件file = io.open("test.lua", "a")-- 在文件最后一行添加 Lua 注释file:write("--test")-- 关闭打开的文件file:close()

文件句柄操作

  • file:seek():用于定位文件位置,支持 setcurend 等参数。
  • file:flush():向文件缓冲中写入所有数据。
  • io.lines("main.lua"):读取指定文件内容,返回迭代函数。

文件操作示例

定位到文件尾并读取

-- 以只读方式打开文件file = io.open("test.lua", "r")-- 定位到文件尾file:seek("end", -25)-- 读取整个文件print(file:read("*a"))-- 关闭文件file:close()

输出结果:

test.lua 文件末尾--test

其他文件操作方法

  • 临时文件io.tmpfile() 创建临时文件,程序结束时自动删除。
  • 检测文件io.type(file) 检测对象是否为有效文件句柄。
  • 读取默认输入io.lines() 读取默认输入设备内容,不关闭文件。

通过以上方法,开发者可以轻松实现 Lua 文件的读写操作。简单模式适合基础需求,完全模式适合高级文件操作。

转载地址:http://dhur.baihongyu.com/

你可能感兴趣的文章
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>
nginx负载均衡的5种策略(转载)
查看>>
nginx负载均衡的五种算法
查看>>
Nginx运维与实战(二)-Https配置
查看>>
Nginx配置ssl实现https
查看>>
Nginx配置TCP代理指南
查看>>
Nginx配置——不记录指定文件类型日志
查看>>
Nginx配置代理解决本地html进行ajax请求接口跨域问题
查看>>
Nginx配置参数中文说明
查看>>
Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
查看>>
Nginx配置如何一键生成
查看>>
Nginx配置实例-负载均衡实例:平均访问多台服务器
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>