這篇文章將為大家詳細(xì)講解有關(guān)PHP讀取文件的常見方法有哪些,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)專注于企業(yè)成都營(yíng)銷網(wǎng)站建設(shè)、網(wǎng)站重做改版、瑤海網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5技術(shù)、商城網(wǎng)站定制開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為瑤海等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。具體如下:
1.fread
string fread ( int $handle , int $length )
fread() 從 handle 指向的文件中讀取最多 length 個(gè)字節(jié)。該函數(shù)在讀取完最多 length 個(gè)字節(jié)數(shù),或到達(dá) EOF 的時(shí)候,或(對(duì)于網(wǎng)絡(luò)流)當(dāng)一個(gè)包可用時(shí),或(在打開用戶空間流之后)已讀取了 8192 個(gè)字節(jié)時(shí)就會(huì)停止讀取文件,視乎先碰到哪種情況。
fread() 返回所讀取的字符串,如果出錯(cuò)返回 FALSE。
如果所要讀取的文件不是本地普通文件,而是遠(yuǎn)程文件或者流文件,就不能用這種方法,因?yàn)?,filesize不能獲得這些文件的大小。此時(shí),你需要通過feof()或者fread()的返回值判斷是否已經(jīng)讀取到了文件的末尾。
例如:
或者:
2.fgets
string fgets ( int $handle [, int $length ] )
fgets()從 handle 指向的文件中讀取一行并返回長(zhǎng)度最多為 length - 1 字節(jié)的字符串。碰到換行符(包括在返回值中)、EOF 或者已經(jīng)讀取了 length - 1 字節(jié)后停止(看先碰到那一種情況)。如果沒有指定 length,則默認(rèn)為 1K,或者說 1024 字節(jié)。
Note: length 參數(shù)從 PHP 4.2.0 起成為可選項(xiàng),如果忽略,則行的長(zhǎng)度被假定為 1024。從 PHP 4.3 開始,忽略掉 length 將繼續(xù)從流中讀取數(shù)據(jù)直到行結(jié)束。如果文件中的大多數(shù)行都大于 8KB,則在腳本中指定較大行的長(zhǎng)度在利用資源上更為有效。從 PHP 4.3 開始本函數(shù)可以安全用于二進(jìn)制文件。早期的版本則不行。
3.fgetss
string fgetss ( resource $handle [, int $length [, string $allowable_tags ]] )
跟fgets功能一樣,但是fgetss會(huì)嘗試從讀取的文本中去掉任何 HTML 和 PHP 標(biāo)記,可以用可選的第三個(gè)參數(shù)指定哪些標(biāo)記不被去掉。
'); } fclose($handle); ?>
4.file
array file ( string $filename [, int $use_include_path [, resource $context ]] )
將文件內(nèi)容讀入一個(gè)數(shù)組中,數(shù)組的每一項(xiàng)對(duì)應(yīng)文件中的一行,包括換行符在內(nèi)。不需要行結(jié)束符時(shí)可以使用 rtrim() 函數(shù)過濾換行符。
$content){ echo 'line '.($line + 1).':'.$content; } ?>
5.readfile
int readfile ( string $filename [, bool $use_include_path [, resource $context ]] )
讀入一個(gè)文件并寫入到輸出緩沖。返回從文件中讀入的字節(jié)數(shù)。如果出錯(cuò)返回 FALSE 并且除非是以 @readfile() 形式調(diào)用,否則會(huì)顯示錯(cuò)誤信息。
6.file_get_contents
string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )
將文件讀入一個(gè)字符串。第三個(gè)參數(shù)$context可以用來設(shè)置一些參數(shù),比如訪問遠(yuǎn)程文件時(shí),設(shè)置超時(shí)等等。
另外,file_get_contents相對(duì)于以上幾個(gè)函數(shù),性能要好得多,所以應(yīng)該優(yōu)先考慮使用file_get_contents。但是readfile貌似比file_get_contents性能好一點(diǎn)(?),因?yàn)樗恍枰{(diào)用fopen。
array( 'timeout' => 1 //設(shè)置超時(shí) ) ) ); echo file_get_contents("http://www.baidu.com/", 0, $ctx); ?>
7.fpassthru
int fpassthru ( resource $handle )
將給定的文件指針從當(dāng)前的位置讀取到 EOF 并把結(jié)果寫到輸出緩沖區(qū)。
8.parse_ini_file
array parse_ini_file ( string $filename [, bool $process_sections ] )
parse_ini_file() 載入一個(gè)由 filename 指定的 ini 文件,并將其中的設(shè)置作為一個(gè)聯(lián)合數(shù)組返回。如果將最后的 process_sections 參數(shù)設(shè)為 TRUE,將得到一個(gè)多維數(shù)組,包括了配置文件中每一節(jié)的名稱和設(shè)置。process_sections 的默認(rèn)值是 FALSE。
注意:
1. 如果 ini 文件中的值包含任何非字母數(shù)字的字符,需要將其括在雙引號(hào)中(")。
2. 有些保留字不能作為 ini 文件中的鍵名,包括:null,yes,no,true 和 false。值為 null,no 和 false 等效于 "",值為 yes 和 true 等效于 "1"。字符 {}|&~![()" 也不能用在鍵名的任何地方,而且這些字符在選項(xiàng)值中有著特殊的意義。
test.ini文件內(nèi)容:
; This is a sample configuration file
; Comments start with ';', as in php.ini
[first_section]
one = 1
five = 5
animal = BIRD
[second_section]
path = "/usr/local/bin"
URL = "/tupian/20230522/ppre>
輸出內(nèi)容:
Array
(
[first_section] => Array
(
[one] => 1
[five] => 5
[animal] => BIRD
)
[second_section] => Array
(
[path] => /usr/local/bin
[URL] => /tupian/20230522/ )
)
幾個(gè)注意事項(xiàng):
1. 鼓勵(lì)在處理二進(jìn)制文件時(shí)使用 b 標(biāo)志,即使系統(tǒng)并不需要,這樣可以使腳本的移植性更好。
2. allow_url_fopen選項(xiàng)激活了 URL 形式的 fopen 封裝協(xié)議使得可以訪問 URL 對(duì)象例如文件。默認(rèn)的封裝協(xié)議提供用 ftp 和 http 協(xié)議來訪問遠(yuǎn)程文件,一些擴(kuò)展庫例如 zlib 可能會(huì)注冊(cè)更多的封裝協(xié)議。出于安全性考慮,此選項(xiàng)只能在 php.ini 中設(shè)置。
3. 如果要打開有特殊字符的 URL (比如說有空格),就需要使用 urlencode() 進(jìn)行 URL 編碼。
關(guān)于“PHP讀取文件的常見方法有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。