php如何讀取文字?
php中讀取檔案內容的幾種方法
1.fread
string fread ( int $handle , int $length )
fread() 從 handle 指向的檔案中讀取最多 length 個位元組。該函數在讀取完最多 length 個位元組數,或到達 EOF 的時候,或(對於網路流)當一個包可用時,或(在開啟使用者空間流之後)已讀取了 8192 個位元組時就會停止讀取檔案,視乎先碰到哪種情況。
推薦:《PHP教學》
fread() 返回所讀取的字串,如果出錯返回 FALSE。
<?php $filename = "/usr/local/something.txt"; $handle = fopen($filename, "r");//讀取二進位制檔案時,需要將第二個引數設定成'rb' //通過filesize獲得檔案大小,將整個檔案一下子讀到一個字串中 $contents = fread($handle, filesize ($filename)); fclose($handle); ?>
如果所要讀取的檔案不是本地普通檔案,而是遠端檔案或者流檔案,就不能用這種方法,因為,filesize不能獲得這些檔案的大小。此時,你需要通過feof()或者fread()的返回值判斷是否已經讀取到了檔案的末尾。
例如:
<?php $handle = fopen('http://www.baidu.com', 'r'); $content = ''; while(!feof($handle)){ $content .= fread($handle, 8080); } echo $content; fclose($handle); ?>
或者:
<?php $handle = fopen('http://www.baidu.com', 'r'); $content = ''; while(false != ($a = fread($handle, 8080))){//返回false表示已經讀取到檔案末尾 $content .= $a; } echo $content; fclose($handle); ?>
2.fgets
string fgets ( int $handle [, int $length ] )
fgets()從 handle 指向的檔案中讀取一行並返回長度最多為 length - 1 位元組的字串。碰到換行符(包括在返回值中)、EOF 或者已經讀取了 length - 1 位元組後停止(看先碰到那一種情況)。如果沒有指定 length,則預設為 1K,或者說 1024 位元組。
<?php $handle = fopen('./file.txt', 'r'); while(!feof($handle)){ echo fgets($handle, 1024); } fclose($handle); ?>
Note: length 引數從 PHP 4.2.0 起成為可選項,如果忽略,則行的長度被假定為 1024。從 PHP 4.3 開始,忽略掉 length 將繼續從流中讀取資料直到行結束。如果檔案中的大多數行都大於 8KB,則在指令碼中指定最大行的長度在利用資源上更為有效。從 PHP 4.3 開始本函數可以安全用於二進位制檔案。早期的版本則不行。
3.fgetss
string fgetss ( resource $handle [, int $length [, string $allowable_tags ]] )
跟fgets功能一樣,但是fgetss會嘗試從讀取的文字中去掉任何 HTML 和 PHP 標記,可以用可選的第三個引數指定哪些標記不被去掉。
<?php $handle = fopen('./file.txt', 'r'); while(!feof($handle)){ echo fgetss($handle, 1024, '<br>'); } fclose($handle); ?>
4.file
array file ( string $filename [, int $use_include_path [, resource $context ]] )
將檔案內容讀入一個陣列中,陣列的每一項對應檔案中的一行,包括換行符在內。不需要行結束符時可以使用 rtrim() 函數過濾換行符。
<?php $a = file('./file.txt'); foreach($a as $line => $content){ echo 'line '.($line + 1).':'.$content; } ?>
5.readfile
int readfile ( string $filename [, bool $use_include_path [, resource $context ]] )
讀入一個檔案並寫入到輸出緩衝。返回從檔案中讀入的位元組數。如果出錯返回 FALSE 並且除非是以 @readfile() 形式呼叫,否則會顯示錯誤資訊。
<?php $size = readfile('./file.txt'); echo $size; ?>
6.file_get_contents
string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )
將檔案讀入一個字串。第三個引數$context可以用來設定一些引數,比如存取遠端檔案時,設定超時等等。
另外,file_get_contents相對於以上幾個函數,效能要好得多,所以應該優先考慮使用file_get_contents。但是readfile貌似比file_get_contents效能好一點(?),因為它不需要呼叫fopen。
<?php $ctx = stream_context_create(array( 'http' => array( 'timeout' => 1 //設定超時 ) ) ); echo file_get_contents("http://www.baidu.com/", 0, $ctx); ?>
7.fpassthru
int fpassthru ( resource $handle )
將給定的檔案指標從當前的位置讀取到 EOF 並把結果寫到輸出緩衝區。
<?php header("Content-Type:text/html;charset=utf-8"); $handle = fopen('./test2.php', 'r'); fseek($handle, 1024);//將指標定位到1024位元組處 fpassthru($handle); ?>
幾個注意事項:
1. 鼓勵在處理二進位制檔案時使用 b 標誌,即使系統並不需要,這樣可以使指令碼的移植性更好。
2. allow_url_fopen選項啟用了 URL 形式的 fopen 封裝協定使得可以存取 URL 物件例如檔案。預設的封裝協定提供用 ftp 和 http 協定來存取遠端檔案,一些擴充套件庫例如 zlib 可能會註冊更多的封裝協定。出於安全性考慮,此選項只能在 php.ini 中設定。
3. 如果要開啟有特殊字元的 URL (比如說有空格),就需要使用 urlencode() 進行 URL 編碼。
以上就是php如何讀取文字的詳細內容,更多請關注TW511.COM其它相關文章!