os - os操作#

示例

-- os模块是lua原生模块, 这份文档是为了方便阐述实际使用中的常见问题

-- 原生文档请查阅 https://wiki.luatos.com/_static/lua53doc/manual.html#6.9

os.remove(path)#

移除文件

参数

传入值类型

解释

string

待移除的文件完整路径

返回值

返回值类型

解释

bool

成功返回true,其他情况返回nil

string

失败时返回原因字符串

例子

-- 删除根目录下的某个文件
os.remove("/1.txt")
-- 注意, 线刷时的文件, 一般在 /luadb 目录, 这个目录下的文件是只读的
-- 也就是无法执行 os.remove("/luadb/xxx.bin")

os.rename(old_path, new_path)#

文件重命名

参数

传入值类型

解释

string

源文件完整路径

string

目标文件完整路径

返回值

返回值类型

解释

bool

成功返回true,其他情况返回nil

string

失败时返回原因字符串

例子

-- 注意, 只有在相同文件系统下的文件可以重命名
-- 例如:
os.rename("/1.txt", "/2.txt")
-- 不同文件系统, 或者源文件系统是只读的, 则无法执行
--os.rename("/luadb/1.txt", "/luadb/2.txt")
--os.rename("/luadb/1.txt", "/2.txt")

os.clock()#

返回程序使用的按秒计 CPU 时间的近似值

参数

传入值类型

解释

return

时间戳

返回值

例子

-- 不推荐使用本API
-- 如需要获取 时间戳, 请使用 os.time()
-- 如需获取系统运行时长, 请使用 mcu.ticks()

os.date(fmt, time)#

日期函数

参数

传入值类型

解释

string

格式化字符串,可以是nil

table

日期时间的table

返回值

返回值类型

解释

table/string

根据fmt的不同,返回值不同

例子

-- 值得注意的几点:
-- 1. 若需要UTC时间, fmt的第一个字符写"!"
-- 2. fmt的格式化遵循 C 函数 strftime, 可以查阅 https://developer.aliyun.com/article/320480

-- 获取本地时间字符串
log.info("本地时间字符串", os.date())
-- 获取UTC时间字符串
log.info("UTC时间字符串", os.date("!%c"))
-- 格式化本地时间字符串
log.info("本地时间字符串", os.date("%Y-%m-%d %H:%M:%S"))
-- 格式化UTC时间字符串
log.info("UTC时间字符串", os.date("!%Y-%m-%d %H:%M:%S"))
-- 格式化时间字符串
log.info("自定义时间的字符串", os.date("!%Y-%m-%d %H:%M:%S", os.time({year=2000, mon=1, day=1, hour=0, min=0, sec=0})))

-- 获取本地时间的table
log.info("本地时间字符串", json.encode(os.date("*t")))
-- 获取UTC时间的table
log.info("UTC时间字符串",  json.encode(os.date("!*t")))

os.time(mytime)#

时间戳函数

参数

传入值类型

解释

table

日期时间的table

return

时间戳

返回值

例子

-- 注意注意, 这个函数返回的是UTC时间戳
-- 时间戳, 但lua下的精度只能到秒
log.info("UTC时间戳", os.time())
log.info("自定义时间戳", os.time({year=2000, mon=1, day=1, hour=0, min=0, sec=0}))

os.difftime(timeA, timeB)#

时间差值

参数

传入值类型

解释

int

时间A,数值类型

int

时间B,数值类型

返回值

返回值类型

解释

int

时间差值

例子