PHP常用的文件操作函數總結
常用PHP文件操作函數
註:文件操作函數的行為受到 php.ini 中設置的影響。
當在 Unix 平臺上規定路徑時,正斜杠 (/) 用作目錄分隔符。而在 Windows 平臺上,正斜杠 (/) 和反斜杠 () 均可使用。
1 :basename()
返回路徑中的文件名。分為帶擴展名和不帶擴展名的。
語法:basename(path,suffix)
Path:必需。規定要檢查的路徑。
Suffix:可選。規定文件擴展名。如果文件有名有文件擴展名,將不會顯示這個擴展名。
// basename $path = "/testweb/home.php"; // 輸出文件名,包含擴展名 echo basename($path) ."<br/>"; // home.php // 輸出文件名,不包含擴展名 echo basename($path,".php"); // home
2 :copy()
復制文件。該函數如果成功則返回 TRUE,如果失敗則返回 FALSE。如果目標文件已存在,將會被覆蓋。
語法:copy(file,to_file)
File:必需。規定要復制的文件。
to_file:必需。規定復制文件的目的地。
// 復制文件,返回值為bool echo copy("source.txt","target.txt");
3 :dirname()
返回路徑中的目錄部分。
語法:dirname(path)
Path:必需。規定要檢查的路徑。
// 返回文件路徑 echo dirname("c:/testweb/home.php")."<br>"; // c:/testweb/ echo dirname("/testweb/home.php"); // /testweb/
4 :disk_free_space()
返回目錄的可用空間。,以字節為單位。
語法:disk_free_space(directory)
Directory:必需。規定要檢查的目錄。(該目錄有限制)
// 返回指定目錄的可用空間(查詢的目錄是有限制的) echo disk_free_space("D:/wwwroot/xxx.com/");
5 :disk_total_space()
返回一個目錄的磁盤總容量。返回字節數
語法:disk_total_space(directory)
Directory:必需。規定要檢查的目錄。
echo disk_total_space("C:/Windows/Temp/"); echo "<hr>";
6 :file_exists()
檢查文件或目錄是否存在。返回bool值
語法:file_exists(path)
Path:必需。規定要檢查的路徑。
// 查看test.txt是否存在,返回bool值 echo file_exists("target.txt"); // 1 echo "<hr>";
7 :file_get_contents()
將文件讀入字符串。
語法:file_get_contents(path,include_path,context,start,max_length)
Path:必需。規定要讀取的文件。
include_path:可選。如果您還想在 include_path(在 php.ini 中)中搜索文件的話,請設置該參數為 '1'。
Context:可選。規定文件句柄的環境。context 是一套可以修改流的行為的選項。若使用 NULL,則忽略。
Start:可選。規定在文件中開始讀取的位置。該參數是 PHP 5.1 中新增的。
max_length:可選。規定讀取的字節數。該參數是 PHP 5.1 中新增的。
// 讀取文件 echo file_get_contents("target.txt"); echo "<hr>";
提示: 該函數是二進制安全的。(意思是二進制數據(如圖像)和字符數據都可以使用此函數寫入。)
8 :file_put_contents()
將字符串寫入文件。如果成功,該函數將返回寫入文件中的字符數。如果失敗,則返回 False。
語法:int file_put_contents ( string filename,mixedfilename , mixed filename,mixeddata [, int flags=0[,resourceflags = 0 [, resource flags=0[,resourcecontext ]] )
File:必需。規定要寫入數據的文件。如果文件不存在,則創建一個新文件。
Data:必需。規定要寫入文件的數據。可以是字符串、數組或數據流。
Mode:可選。規定如何打開/寫入文件。可能的值:FILE_USE_INCLUDE_PATH/FILE_APPEND/LOCK_EX
Context:可選。規定文件句柄的環境。context 是一套可以修改流的行為的選項。
// 寫入文件 echo file_put_contents("sites.txt","Runoob"); echo "<hr>";
9 :filesize()
函數返回指定文件的大小。
如果成功,該函數返回文件大小的字節數。如果失敗,則返回 FALSE。
語法:filesize(filename)
Filename:必需。規定要檢查的文件。
// 返回文件大小 echo filesize("target.txt"); echo "<hr>";
10 :filetype()
函數返回指定文件或目錄的類型。
若成功,則返回 7 種可能的值。若失敗,則返回 false。
語法:filetype(filename)
Filename:必需。規定要檢查的文件。
// 返回文件類型 echo filetype("target.txt"); echo "<hr>";
11 :glob()
返回一個包含匹配指定模式的文件名/目錄的數組。
glob() 函數返回匹配指定模式的文件名或目錄。
該函數返回一個包含有匹配文件 / 目錄的數組。如果出錯返回 false。
語法:glob(pattern,flags)
File:必需。規定檢索模式。
Size:可選。規定特殊的設定。
- GLOB_MARK – 在每個返回的項目中加一個斜線
- GLOB_NOSORT – 按照文件在目錄中出現的原始順序返回(不排序)
- GLOB_NOCHECK – 如果沒有文件匹配則返回用於搜索的模式
- GLOB_NOESCAPE – 反斜線不轉義元字符
- GLOB_BRACE – 擴充 {a,b,c} 來匹配 'a','b' 或 'c'
- GLOB_ONLYDIR – 僅返回與模式匹配的目錄項
- GLOB_ERR – 停止並讀取錯誤信息(比如說不可讀的目錄),默認的情況下忽略所有錯誤
註釋:GLOB_ERR 是 PHP 5.1 添加的。
echo "<pre>"; var_dump(glob("*.*")); echo "<hr>";
12 :is_dir()
判斷指定的文件名是否是一個目錄。
語法:is_dir(file)
File:必需。規定要檢查的文件。
$file = "D:/wwwroot/xxx.com/"; if(is_dir($file)) { echo ("$file is a directory"); } else { echo ("$file is not a directory"); } echo "<hr>";
13 :is_writable()
判斷文件是否可寫。如果文件存在並且可寫則返回 true。
語法:is_writable(file)
File:必需。規定要檢查的文件。
$file = "target.txt"; if(is_writable($file)) { echo ("$file is writeable"); } else { echo ("$file is not writeable"); } echo "<hr>";
14 :mkdir()
創建目錄,如果成功該函數返回 TRUE,如果失敗則返回 FALSE。
語法:mkdir(path,mode,recursive,context)
Path:必需。規定要創建的目錄的名稱。
Mode:可選。規定權限。默認是 0777(允許全局訪問)。
mode 參數由四個數字組成:
第一個數字通常是 0
第二個數字規定所有者的權限
第三個數字規定所有者所屬的用戶組的權限
第四個數字規定其他所有人的權限
可能的值(如需設置多個權限,請對下面的數字進行總計):
1 = 執行權限
2 = 寫權限
4 = 讀權限
Recursive:可選。規定是否設置遞歸模式。(PHP 5 中新增的)
Context:可選。規定文件句柄的環境。context 是一套可以修改流的行為的選項。(PHP 5 中新增的)
echo mkdir("testing"); echo "<hr>";
註釋: mode 參數在 Windows 平臺上被忽略。
15 :move_uploaded_file()
將上傳的文件移動到新位置。若成功,則返回 true,否則返回 false。
文件上傳的核心就是這個文件
語法:move_uploaded_file(file,newloc)
File:必需。規定要移動的文件。
Newloc:必需。規定文件的新位置。
註釋:本函數僅用於通過 HTTP POST 上傳的文件。
註意:如果目標文件已經存在,將會被覆蓋。
16 :parse_ini_file()
函數解析一個配置文件(ini 文件),並以數組的形式返回其中的設置。
語法:parse_ini_file(file,process_sections)
File:必需。規定要檢查的 ini 文件。
process_sections:可選。如果設置為 TRUE,則返回一個多維數組,包括瞭配置文件中每一節的名稱和設置。默認是 FALSE。
echo "<pre>"; var_dump(parse_ini_file("test.ini")); echo "<hr>";
註:此ini文件不一定非的是php.ini,也可以是你自己的ini配置文件。
17 :realpath()
該函數刪除所有符號連接(比如 '/./', '/../' 以及多餘的 '/'),並返回絕對路徑名。
如果失敗,該函數返回 FALSE。
語法:realpath(path)
Path:必需。規定要檢查的路徑。
echo realpath("test.ini");
18 :rename()
rename() 函數重命名文件或目錄。
如果成功,該函數返回 TRUE。如果失敗,則返回 FALSE。
語法:rename(oldname,newname,context)
Oldname:必需。規定要重命名的文件或目錄。
Newname:必需。規定文件或目錄的新名稱。
Context:可選。規定文件句柄的環境。context 是一套可以修改流的行為的選項。
echo rename("test.ini","testss.ini"); echo "<hr>";
19 :tempnam()
創建唯一的臨時文件。若成功,則該函數返回新的臨時文件名。若失敗,則返回 false。
語法:tempnam(dir,prefix)
Dir:必需。規定創建臨時文件的目錄。
Prefix:必需。規定文件名的開頭。
echo tempnam("D:wwwrootxxx.com","TMP0"); echo "<hr>";
註: 此方法創建的文件,如果不再需要該文件則要刪除此文件,不會自動刪除的。
20 :tmpfile()
建立臨時文件。此函數創建的臨時文件會在文件關閉後(用 fclose())或當腳本結束後自動被刪除。
語法:tmpfile()
$temp = tmpfile(); fwrite($temp, "Testing, testing."); // 將文件指針的位置倒回文件的開頭。 rewind($temp); // 從文件中讀取1K數據 echo fread($temp,1024); //This removes the file fclose($temp);
21:unlink()
刪除文件。如果成功,該函數返回 TRUE。如果失敗,則返回 FALSE。
語法:unlink(filename,context)
Filename:必需。規定要刪除的文件。
Context:可選。規定文件句柄的環境。context 是一套可以修改流的行為的選項。
// 如果沒有text.txt文件,這樣寫輸出的結果會報警告,測試代碼,就這樣瞭 // 實際用的時候,需要註意這個問題 $file = "test.txt"; if (!unlink($file)) { echo ("Error deleting $file"); } else { echo ("Deleted $file"); }
22 :chmod()
改變文件權限。如果成功則返回 TRUE,如果失敗則返回 FALSE。
語法:chmod(file,mode)
File:必需。規定要檢查的文件。
Mode:必需。規定新的權限。
mode 參數由 4 個數字組成:
第一個數字通常是 0
第二個數字規定所有者的權限
第三個數字規定所有者所屬的用戶組的權限
第四個數字規定其他所有人的權限
可能的值(如需設置多個權限,請對下面的數字進行總計):
1 = 執行權限
2 = 寫權限
4 = 讀權限
echo chmod("target.txt",0600); echo "<hr>";
23:chown()
改變文件所有者。如果成功則返回 TRUE,如果失敗則返回 FALSE。
語法:chown(file,owner)
File:必需。規定要檢查的文件。
Owner:必需。規定新的所有者。可以是用戶名或用戶的 ID。
echo chown("target.txt","root"); echo "<hr>";
24:chgrp()
改變文件組。如果成功則返回 TRUE,否則返回 FALSE。
語法:chgrp(file,group)
File:必需。規定要檢查的文件。
Group:可選。規定新的組。可以是組名或組的 ID。
echo chgrp("test.txt","admin"); echo "<hr>";
到此這篇關於PHP常用的文件操作函數總結的文章就介紹到這瞭,更多相關PHP文件操作函數內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!