Lua標準庫-輸入輸出處理(input and output facilities)
I/O庫提供兩種不同的方式進行文件處理
1、io表調(diào)用方式:使用io表,io.open將返回指定文件的描述,并且所有的操作將圍繞這個文件描述
io表同樣提供三種預定義的文件描述io.stdin,io.stdout,io.stderr
2、文件句柄直接調(diào)用方式,即使用file:XXX()函數(shù)方式進行操作,其中file為io.open()返回的文件句柄
多數(shù)I/O函數(shù)調(diào)用失敗時返回nil加錯誤信息,有些函數(shù)成功時返回nil
1、io.close ([file])
功能:相當于file:close(),關(guān)閉默認的輸出文件
2、io.flush ()
功能:相當于file:flush(),輸出所有緩沖中的內(nèi)容到默認輸出文件
3、io.lines ([filename])
功能:打開指定的文件filename為讀模式并返回一個迭代函數(shù),每次調(diào)用將獲得文件中的一行內(nèi)容,當?shù)轿募矔r,將返回nil,并自動關(guān)閉文件
若不帶參數(shù)時io.lines() <=> io.input():lines(); 讀取默認輸入設(shè)備的內(nèi)容,但結(jié)束時不關(guān)閉文件
如:for line in io.lines("main.lua") do
print(line)
end
4、io.open (filename [, mode])
功能:按指定的模式打開一個文件,成功則返回文件句柄,失敗則返回nil+錯誤信息
mode:
"r": 讀模式 (默認);
"w": 寫模式;
"a": 添加模式;
"r+": 更新模式,所有之前的數(shù)據(jù)將被保存
"w+": 更新模式,所有之前的數(shù)據(jù)將被清除
"a+": 添加更新模式,所有之前的數(shù)據(jù)將被保存,只允許在文件尾進行添加
"b": 某些系統(tǒng)支持二進制方式
5、io.output ([file])
功能:相當于io.input,但操作在默認輸出文件上
6、io.popen ([prog [, mode]])
功能:開始程序prog于額外的進程,并返回用于prog的文件句柄(并不支持所有的系統(tǒng)平臺)
7、io.read (...)
功能:相當于io.input():read
8、io.tmpfile ()
功能:返回一個臨時文件句柄,該文件以更新模式打開,程序結(jié)束時自動刪除
9、io.type (obj)
功能:檢測obj是否一個可用的文件句柄
返回:
"file":為一個打開的文件句柄
"closed file":為一個已關(guān)閉的文件句柄
nil:表示obj不是一個文件句柄
10、io.write (...)
功能:相當于io.output():write
11、file:close()
功能:關(guān)閉文件
注:當文件句柄被垃圾收集后,文件將自動關(guān)閉。句柄將變?yōu)橐粋€不可預知的值
12、file:flush()
功能:向文件寫入緩沖中的所有數(shù)據(jù)
13、file:lines()
功能:返回一個迭代函數(shù),每次調(diào)用將獲得文件中的一行內(nèi)容,當?shù)轿募矔r,將返回nil,但不關(guān)閉文件
如:for line in file:lines() do body end
14、file:read(...)
功能:按指定的格式讀取一個文件,按每個格式函數(shù)將返回一個字串或數(shù)字,如果不能正確讀取將返回nil,若沒有指定格式將指默認按行方式進行讀取
格式:
"*n": 讀取一個數(shù)字
"*a": 從當前位置讀取整個文件,若為文件尾,則返回空字串
"*l": [默認]讀取下一行的內(nèi)容,若為文件尾,則返回nil
number: 讀取指定字節(jié)數(shù)的字符,若為文件尾,則返回nil;如果number為0則返回空字串,若為文件尾,則返回nil;
15、file:seek([whence][,offset])
功能:設(shè)置和獲取當前文件位置,成功則返回最終的文件位置(按字節(jié)),失敗則返回nil加錯誤信息
參數(shù)
whence:
"set": 從文件頭開始
"cur": 從當前位置開始[默認]
"end": 從文件尾開始
offset:默認為0
不帶參數(shù)file:seek()則返回當前位置,file:seek("set")則定位到文件頭,file:seek("end")則定位到文件尾并返回文件大小
16、file:setvbuf(mode,[,size])
功能:設(shè)置輸出文件的緩沖模式
參數(shù)
mode:
"no": 沒有緩沖,即直接輸出
"full": 全緩沖,即當緩沖滿后才進行輸出操作(也可調(diào)用flush馬上輸出)
"line": 以行為單位,進行輸出(多用于終端設(shè)備)
最后兩種模式,size可以指定緩沖的大小(按字節(jié)),忽略size將自動調(diào)整為最佳的大小
17、file:write(...)
功能:按指定的參數(shù)格式輸出文件內(nèi)容,參數(shù)必須為字符或數(shù)字,若要輸出其它值,則需通過tostring或string.format進行轉(zhuǎn)換
原文鏈接:http://tech.it168.com/j/2008-02-17/200802171019138.shtml