
那如果我們以“\”分隔符寫入路徑會怎樣呢?
<?php $fp = fopen("C:\wamp64\www\text.txt",'w'); ?>運行後報錯,提示路徑參數無效

所以我們要把分隔符“\”換成“/”:
<?php $fp = fopen("C:/wamp64/www/text.txt",'w'); ?>運行時無報錯,說明參數是有效的。 【註意】fopen函數不能理解“\”分隔符,如果你想要使用“\”,那麽要使用轉義,如寫成:"C:\\wamp64\\www\\text.txt"這種寫法也是可以的,函數也能理解,不會報錯。但即使這樣,也不推薦使用“\”,因為在OS(mac)下只能識別“/”不能識別“\” 本小節的結論:推薦堅持使用“/”作為分隔符 2.相對路徑: 上一小節介紹的是絕對路徑的寫法,但這樣卻帶來了另外一個問題:服務器的目錄結構可能會有較大的改變,這時原來寫的絕對路徑就要全部重寫了,比如在我的電腦上的目標文件路徑是C:/wamp64/www/text.txt,如果我把www文件夾改名為penghuwan呢?原來寫入的路徑參數就失效了。所以我們引入了相對路徑的寫法:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'w'); ?>? $_SERVER是PHP的超級全局變量(在代碼任何地方都可訪問,類型是數組),通過$_SERVER['DOCUMENT_ROOT']可取到服務器的默認根目錄 服務器的默認根目錄可通過php.ini修改(這個可自行百度) ? $_SERVER['DOCUMENT_ROOT']在這裏等同於C:/wamp64/www 本小節的結論:推薦使用相對路徑 <2>fopen的第二個參數為打開模式 設置打開模式後,我們就相當於為接下來的讀寫操作設置了權限: 最基本的幾個模式: “r”:只能讀取文件,不能寫入文件(寫入操作被忽略) “w”:只能寫入文件,不能讀取文件(讀取操作被忽略) “a”:只追加文件,與“w”類似,區別是“w”刪除原有的內容,“a”不刪除原有內容,只追加內容
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'w'); fwrite($fp,'在寫模式下寫入'); fclose($fp); ?>在設置了寫操作的權限後,就能正常地寫入文件了 運行後打開C:/wamp64/www/text.txt:

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); fwrite($fp,'在讀模式下寫入'); fclose($fp); ?>運行後打開C:/wamp64/www/text.txt,發現文件內容並沒有改變,說明由於沒有設置相應的權限,操作被忽略了


很全面,但我覺得這張表對新手有些不太友好,讓人看後不知多雲。 r是只讀,w是只寫(原來有的內容全刪除),a是追加(不刪除原有內容),這都好理解。
但r+,w+,和a+的區別和聯系講的實在太模糊了呀。 這裏我就想詳細地講一下r+,w+,和a+三者的區別和聯系: 首先r+,w+,和a+都是可讀可寫的,讀取時的方式是一樣的,關鍵在於寫入方式的不同: r+: 從文件[頭部][覆蓋]原有內容 ([不刪除]原有內容); a+:從文件[尾部][追加]內容 ([不刪除]原有內容); w+:[完全刪除]原有內容,然後[再添加]新的內容 下面我依次演示上述的結論,首先我們沒有寫入的時候文本是”I am initialized value”(意為我是初始值)
? 采用r+模式寫入文本“r+ mode”
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r+'); fwrite($fp,'r+ mode'); fclose($fp); ?>運行後再打開文本,發現“I am in”被“r+ mode”覆蓋了:

? 采用a+模式寫入文本“a+ mode” 基於”I am initialized value”的初始文本我們運行以下代碼:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'a+'); fwrite($fp,'a+ mode'); fclose($fp); ?>

I am initialized value沒有被刪除和覆蓋,而是在後面追加了a+ mode的這一段新文本 運行多次後:

?采用w+模式寫入文本“w+ mode”
基於”I am initialized value”的初始文本我們運行以下代碼:<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'w+'); fwrite($fp,'w+ mode'); fclose($fp); ?>運行後,我們發現”I am initialized value”已經被刪除了,然後才加上了“w+ mode”這段新文本


讀取文件的方式有以下幾種: 1.一次讀取一個字節的數據 fgetc() 2.一次讀取指定的字節數的數據 fread() 3.一次讀取一行數據 fgets()/fgetcsv() 4.一次讀完全部數據 fpassthru()/ file() 1. 一次讀取一個字節 —— 通過fgetc()獲取單個字節
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r');//打開文件 if(file_exists("$DOCUMENT_ROOT/text.txt")){//當文件存在時,才讀取內容 while(!feof($fp)){//判斷文件指針是否到達末尾 $c = fgetc($fp);//每執行一次fgetc(),文件指針就向後移動一位 echo $c;//輸出獲取到的字節 } } fclose($fp);//關閉文件 ?>運行:

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fgetc($fp);//只做一次輸出 close($fp); ?>運行結果如下,我們得到的不是漢字“我”,而是一個亂碼,其實這個亂碼就是一個字節

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fgetc($fp);//連續做三次輸出 echo fgetc($fp); echo fgetc($fp); fclose($fp); ?>
2.一次讀取多個字節 ——通過fread()方法:
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fread($fp, 3);//一次輸出三個字節即一個漢字字符(UTF-8) fclose($fp); ?>
運行結果:

改成:
echo fread($fp, 6);
運行結果如下,輸出了6個字節也即兩個漢字字符(UTF-8)

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT'] $fp = fopen("$DOCUMENT_ROOT/text.txt",'r');//打開文件 if(file_exists("$DOCUMENT_ROOT/text.txt")){//當文件存在時,才讀取內容 while(!feof($fp)){//判斷文件指針是否到達末尾 $line = fgets($fp);//返回一行文本,並將文件指針移動到下一行頭部 echo $line."<br/>";//輸出獲取到的一行文本 } } fclose($fp);//關閉文件 ?>

$line = fgets($fp,10);Demo:

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); fpassthru($fp); fclose($fp); ?>
運行結果:

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $file_array = file("$DOCUMENT_ROOT/text.txt");//取到文件數組 foreach ($file_array as $value) {//輸出數組元素 echo $value."<br/>"; } ?>

【註意】:這裏我們並不需要寫fopen和fclose哦!也就是說file()方法已經幫我們做了這一步了 四.使用fclose方法關閉文件 fclose()將返回一個布爾值,成功關閉為true,關閉失敗為false(失敗的情況很少出現,可不考慮) 是否打開文件後一定要關閉? 1即使不手寫fclose,在PHP腳本執行結束後,也會自動關閉文件的 2但在一個長時間執行的腳本中,如果不寫關閉文件的fclose(),在文件加鎖的情況下會造成操作的阻塞,所以,寫fclose是個好習慣 五.文件指針的移動 我們上面調用的讀取文件的函數,其實都是基於文件指針去打印的,每讀取一段字節內容,文件指針就向後移動一段字節長度,直到被讀取的文件最大字節長度為止
<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; function print_file_pointer($fp){//定義一個打印文件指針位置的函數 echo " <br/>//此時文件指針的位置:"; echo ftell($fp)."<br/>"; } $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); echo fgetc($fp);//通過fgetc連續輸出三個字節 echo fgetc($fp); echo fgetc($fp); print_file_pointer($fp);//打印此刻文件指針的位置 echo fread($fp,6);//通過fread一次輸出6字節 print_file_pointer($fp);//打印此刻文件指針的位置 echo fgets($fp); //通過fgets輸出一整行 print_file_pointer($fp);//打印此刻文件指針的位置 fpassthru($fp); //一次性輸出全部內容 print_file_pointer($fp);//打印此刻文件指針的位置 fseek($fp, 33);//使文件指針移動到33字節位置 print_file_pointer($fp);//打印此刻文件指針的位置 rewind($fp);//使文件指針移動到0字節位置(初始位置) print_file_pointer($fp);//打印此刻文件指針的位置 $fclose($fp); ?>
Demo:

<?php $DOCUMENT_ROOT = $_SERVER['DOCUMENT_ROOT']; $fp = fopen("$DOCUMENT_ROOT/text.txt",'r'); while(!feof($fp)){ echo fgets($fp); echo ftell($fp); } fclose($fp); ?>
我們在windows下敲下回車鍵的時候,相當於鍵入了\n\r,所以“我叫彭湖灣”的15字節+“\n\r”的2字節 = 17字節


Tags: Windows windows 服務器 小夥伴 文章
文章來源: