程式在寫時, 何時要用 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.
更多推薦文章
This work, unless otherwise expressly stated, is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.


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. 第一行先換行, 從第二行開始抓, 就會是正確的資料了~
解決了,x 的,這個問題卡了我半個小時...
嗯嗯, 這個問題如果不知道有 BOM 的話, 大概一個月都解不掉吧.. XD
你好,請問一下,我現在想要讀取CA SERVER 所發出來的憑證(加解密的公、私鑰)
上面的程式碼要如何去修正
把 10 改成 20480 之類的吧, 把數字加大就對了~
我照上面的範例打(其實是直接copy)
可是fread的輸出結果並未分成兩行
而是直接輸出成abcdefg 12
why?
看看你的文字檔後面是不是有很多空白, 是空白造成的斷行, 而不是本身的 \n.