星期一, 八月 04, 2008
PHP: 讀取檔案 fgets 和 fread 的差異
程式在寫時, 何時要用 fgets? 何時要用 fread? 主要的差異在哪邊? 以下就用簡單的範例來說明~
先建立一個檔案: /tmp/readfile.txt, 內容如下:
abcdefg
123456789
寫兩隻簡單的小程式:
fgets 版
<?php
$handle = fopen('/tmp/readfile.txt', "r");
$contents = '';
if ($handle) {
while (!feof($handle)) {
$contents = fgets($handle, 10);
echo $contents;
exit;
}
fclose($handle);
}
?>
執行得到的內容:
abcdefg
fread 版
<?php
$handle = fopen('/tmp/readfile.txt', "r");
$contents = '';
if ($handle) {
while (!feof($handle)) {
$contents .= fread($handle, 10);
echo $contents;
exit;
}
fclose($handle);
}
?>
執行得到的內容:
abcdefg
12
fgets 和 fread 主要的差異
- fgets 是 一次讀一行 (Gets a line from file pointer.)
- fread 會把整個檔案都讀出來, 然後再去看要抓多少 bytes.
所以 fgets 讀到的是第一行到結束(後面參數不加, 就會讀到此行結束), fread 讀到的是 "abcdefg\n12" (\n 算一個 bytes), 就是看到的結果囉~
使用的時機就自行看情況囉~ 若讀的檔案太大, 建議使用 fgets. :)
相關標籤
請教抓取一行的文字字串
Hi 宗董,
我這個外行人又來發問了:
如果 file.txt 裡面有以下的資料
http://www.yahoo.com
http://www.google.com
我想用 substr 抓取 7 和 -4 之間的字串,即 yahoo, google
但我發現:
1) 如果 file.txt 是 utf-8 編碼,會抓錯資料
2) 如果 file.txt 是 ansi 編碼,就正常
請問是為什麼呢?
謝謝
回 小木可
因為 Windows 記事本存 UTF-8 會有另外多存 BOM.
詳可見: http://plog.longwin.com.tw/programming/2008/06/17/php_check_remove_bom_utf8_2008
那 BOM 是看不到的, 不過還是占 3 bytes. 所以會造成抓錯.
解法:
1. 不要用記事本存檔, 用其它編輯器(Editplus 可以設定存檔時不會自動加上 BOM)
2. 第一行先換行, 從第二行開始抓, 就會是正確的資料了~ :)
有問題想問
你好,請問一下,我現在想要讀取CA SERVER 所發出來的憑證(加解密的公、私鑰)
上面的程式碼要如何去修正
讀不出\n
我照上面的範例打(其實是直接copy)
可是fread的輸出結果並未分成兩行
而是直接輸出成abcdefg 12
why?
發表迴響
PS2: 若您的留言被誤判, 我都會再自行看過, 不需要一直重覆張貼~




