PHP之常用的函數總結

本文參考自:點擊打開鏈接

最近學了好久的PHP了,今天就有關的函數總結一下,在參考別人寫的博客的基礎上,價值自己的理解,與大家分享:

1.php基礎語法

變量,常量
嚴格區分大小寫,但內置結構或關鍵字無所謂(echo)
命名:不能以數字,空格,.來開頭,但是可以有漢字,eg:$變量="aa";
可變變量:$a='aa';$$a="bb";則 $aa="bb";
引用賦值:$a="aa"; $b=&$a; 則改變$a的值,$b也變化。不同:存儲結構是分開的,即使unset($a),$b還在(區分C語言)
變量類型:int str array bool object float resource null
全局變量:全局變量本身就是靜態存儲方式,所有的全局變量都是靜態變量
$_SESSION, $_COOKIE, $_POST, $_GET, $_REQUEST, $_FILES,$_EVN
靜態變量:
static 
靜態方法:靜態方法不需要所在類被實例化就可以直接使用。Math::Max($a,$b);(未實例化Math類直接調用靜態方法Max)
常量:
define("NAME",$value,[TRUE]);//如果第三個參數爲true,則不區分大小寫,默認是區分大小寫的
預定義常量:


PHP_OS="WINDOWS"; PHP_VERSION="版本";
E_ERROR=1,錯誤,導致腳本終止; E_WARNING=2,警告,腳本不終止 ;E_NOTICE=8,非關鍵性錯誤
魔術常量:【全是返回物理路徑,即使被包含輸出,輸出的也是源頭代碼的信息,非當前包含文件的信息,和$_SERVER區分】


__FILE__ 當前文件名稱
__CLASS__ 當前類名稱
__FUNCTION__ 當前函數名稱
__METHOD__ 當前方法名稱
__LINE__ 當前行數名稱


類型轉換
1.setType($a);//獲取變量的類型
2.$b=(int)$a;//把$a轉換爲整形
$b=intval($a);
3.is_int($b);//判斷$b是否爲整形,返回bool值

類型轉換:(int),(bool),(float),(),(string),(),(array),(),(object);
intval(),floatval();strval()
判斷類型:
is_bool/int/float/string/array/object/resource/null
is_numberic();'//判斷是否爲任何類型的數字或者數組字符串
is_callable();//判斷是否爲有效函數名稱
運算符
算數運算符:+ - * / % ++ --
連接運算符: .
賦值運算符: =, +=,-=,*=,/=,%=,.=
比較運算符:>,<,==,===,!= <>,!==
邏輯運算符: and,&& ; or,|| ; not,! ; xor(邏輯異或,兩邊不同返回TRUE,相同返回FALSE)
位運算符 : & ;|;^(異或,不同返回1);~(非運算符,1.0取反);<<左移,右邊空出的補0;>>右移左邊空出的補0
其他運算符:
?: 三目運算符 舉例:$a=$bool?$b:$c; //若$bool成立,$a=$b;否則$a=$c
@ 忽略錯誤
=>數組下標用
->調用對象值用
·· 反引號爲執行運算符??
instanceof 類型運算符 class ClassOne{} $a=new ClassOne(); var_dump( $a instanceof ClassOne );//返回true
流程控制

1.if(){}else{}
2.while(){};
3.do{}while();$
4.for($a=1;$a<10;$a++){}
5.switch($a){
case 1:echo 1; break;
case 2:echo 2;break;
default: echo "this is defaut value";
}
continue,break;exit 區別:
continue跳過當前循環,循環還在繼續
break 跳出當前循環,循環終止
exit; 終止當前腳本,這行代碼後邊的代碼不執行了就
函數
命名:遵循變量命名規則即可,函數不可一被重載、
作用:函數實現了結構化編程,提高了代碼的可維護性

全局變量:整個腳本中皆可以使用
局部變量:只有在函數體內使用,執行完函數自動釋放
|---> 分爲靜態存儲類型和動態存儲類型; static $a爲靜態變量,函數執行完後,不會被釋放
函數內局部變量編程全局變量:1.global ; 2.$GLOBAL['']使用全局數組

幾種類型函數
1.引用參數的函數:function(&$a){}//函數內對形參$a的操作,會對實參也造成影響 eg:sort()
2.默認參數的函數:function($a=0){}//沒有參數傳入的話,默認$a=0
3.可變參數個數的函數:function($a,$b$c,...){}
//原理:通過fun_get_args()函數,接受所有參數並返回一個數組來使用,所以可以有多個參數 EG: echo(),array_merge()
4.回調函數:$fun="one"; function one(){} 當調用$fun()的時候,就是再調用one()函數,call_user_func_array()
5.遞歸函數:function test(){ test()}//在函數中再次調用函數,但注意死循環的問題,要有執行結束跳出

2.PHP常用函數

常用函數:
    echo()【語言結構】
    print()//【語言結構】【有返回值】,若傳輸失敗導致沒有輸出,它返回false
    var_dump()
    var_export()【有返回值,翻譯一個合法的PHP代碼】
    printf()//類似與C語言的形式 printf("my name is %s, age %d", $name, $age);,打印出來
    sprintf()//跟printf相似,但不打印,而是返回格式化後的文字,其他的與printf一樣

數組函數:
1.排序類:【1.無返回值,傳值引用,就直接對原數組進行了修改】
    按V:sort,rsort,asort,arsort,
    按K:ksort,krsort
    按字母:natsort();//區分大小寫的排序
              natcasesort();//不區分大小寫的排序,
              當遇到字符完全一樣,按照數字排 eg: FILE1,FILE2, 這兩個字符相同,再按照數字1<2排,所以結果  FILE1,FILE2
    回調:usort($arr,"strnatcmp")//回調類的排序,把$arr數組裏的每一個元素丟到strnatcmp()[非自然數排序]處理【返回新的排序數組】
    規律:
            沒有"k",排序按照【value】排序,排序有"a"的表示要保留KEY,有"r"的倒序排
             有“k”,排序按照【KEY】排序,有"r"的倒序排
             有"u"的,表示要丟到回調函數中處理的

  2.鍵值操作類:【都有返回值,沒有在原來參數上修改】
        1.array_values($arr);//獲取$arr中的值重排,去掉下標【返回值新索引數組】
        2.array_keys($arr[,"str",true])//獲取$arr中所有字符是"str"的下標,形成索引數組,true表示區分大小寫【返回新索引數組】
        3.array_search("is",$arr[,true]) //返回值"is"在$arr中的key,找不到返回fales,true表示嚴格按照類型(8,"8")【返回第一個匹配值】
        4.in_array("str",$arr);//判斷"str"在$arr中是否存在,【返回BOOL】
        5.is_array($arr);//判斷是否是數組【返回BOOL】
        6.array_key_exists($key,$arr); //查詢$arr中是否有$key,【返回BOOL】
        7.array_flip($arr);// 交換鍵值,如有重複,後來居上,【返回新數組】
        8.array_reverse($arr,[true|false]);//數組順序反轉,param2是否保留原來鍵值【返回新關聯/索引數組】
        9.array_column(array(),'name'[,name_two]) — 返回數組中指定的name列[可選參數,如果有返回name=>name_two的形式]【返回一維數組】

   3.元素個數和唯一性
        1.array_unique($arr);//去掉$arr中的重複值,重複的保留第一個值,【返回數組,鍵值保留】
        2.array_count_values($arr)//統計數組值出現的次數,【返回數組,KEY爲原來數組的值,VALUE爲統計的次數】
        3.count($arr[,1])/sizeof();//統計$arr的元素個數,參數"1"表示統計多維數組開啓,默認0爲關閉【返回統計個數】

  4.回調函數
        1.array_filter($arr,"function");//把$arr放到函數function中處理,【返回判斷爲TRUE的數據組成新數組,鍵值保留】
        2.array_walk($arr,"function"[,"data"]);//把$arr放到function(&$v,$k,$data)中處理【返回值爲bool】
        3.array_map("function",$arr,$arr2,$arr3,....);//把所有數組返回到回調函數統一處理,【返回數組】
        4.array_reduce($arr,myfunction[,initial]):把一維數組$arr中的值依次傳到自定義函數myfunction($v1,$v2)的v2上,v1爲累加值類似於( .= ),[如果有initial,先把其當v1傳進去]【返回字符串】

  5.拆分,合併,分解,接合數組
        1.array_slice($arr,1[,2]);//在$arr中,從第二個開始取[,返回倆個值]【返回新數組(對原數組無影響),鍵值保留】
        2.array_splice($arr,1[,2,"aaa","bb"]);//刪除或替換,從$arr第二個開始取,刪除或替換2個值【返回值爲新數組,拆掉原數組】
        3.array_combine($arr1,$arr2);//數組$arr1爲KEY,$arr2爲VALUES結合形成新索引數組【返回索引數組】
        4.array_merge($arr1,$arr2,$arr3...);//數組進行合併,保留鍵值,有重複,後來者居上【返回新數組】
               array_merge發現有key值相同的,取後者;
               $arr1+$arr2 發現有key值相同的,取前者,第二個重複的值丟棄
        5.array_intersect($arr1,$arr2)//返回兩個數組的交集,鍵值不變
        6.array_diff($arr1,$arr2)//返回兩數組的差集,返回的值爲第一個數組的值,鍵值不變
        7.array_chunk($arr,2)//分割數組,把$arr按照【2個爲一組】均等分割【返回一個二維數組】

  6.數組的數據結構【2.無返回值,傳值引用,就直接對原數組進行了修改】
        1.array_shift($arr)//從開頭,刪除數組第一個元素
        2.array_unshift($arr,"one","two")//從開頭,添加元素
        3.array_pop($arr)//從結尾,刪除數組最後一個元素
        4.array_push($arr,"aaa");//從結尾,添加元素
        
        6.current($arr)//返回數組中的當前單元 比如是關聯數組是不知道下標,可以輸出當前數組的辦法解決
        7.key($arr)//返回當前指針指向元素的鍵值
        8.next($arr)//當前指針下移
        9.pre($arr)//當前指針上移
        10.end($arr)//指針指到最後
        11.reset($arr)//指針迴歸到開頭
        
        12.unset($arr)//銷燬此數組

  7.其他
        1.array_rand($arr,2);//隨機返回兩個$arr數組當中的key【返回值爲值或者數組】
        2.shuffle($arr)//隨機的重組$arr,順序變亂【返回新數組,保留鍵值】
        3.array_sum($arr);//返回$arr的value的和【返回一個值】
        4.range(0,10,2,)//快速創建0,10的數組,間隔爲2,所以有5個值【返回新索引數組】
        5.http_build_query($arr)//把關聯數組轉換成一個經過urlencode加密的URL eg:array["a"=>2];=>URL:a=2&
       

字符串函數
       返回bool
            1.isset($a)//當$a=NULL 或不存在,返回false,反之爲true
            2.empty($a)//當$a=NULL/''/array()/0/'0'/不存在 時 返回true,反之爲false


        返回值爲自字符
            1.substr(字符串,開始地方,[返回字符串的長度]);// 截取字符串的一部分,第一個字符位置爲0
            2.substr_replace($str,"aaa",start[,length]);在$str上操作,從第start個開始,把【後邊】的字符[全/或length個]替換
            3.sub_count($str,"is"[,5,10]);//[ 從第五個字符開始,搜索長度爲10,]搜索is在$str中出現的次數,【返回次數】
            4.strstr($email,"@"[,true])    //從頭開始搜索,無true返回@後邊字符,有true返回@前邊的字符[strrchr對比]
            5.strrchr($email,"@")//從結尾開始搜索,返回@後的所有字符
            6.str_replace(被替換詞,替換詞,被搜索字符串,[統計替換次數$num])   前兩個參數也可爲數組,兩個數組元素個數相同
            7.str_repeat($str,num);//重複$str字符串 num次,

          返回值爲數字類的
             1.strpos($str,"@");//返回@【第一次出現的位置】
             2.strrpos($str,"@");//返回@【最後一次出現的位置】
             3.str_word_count($str[,0/1/2]);
                    //返回$str中單詞的數量[0指返回次數,默認值/1指以數組形式返回單詞值/2指返回關聯數組,k爲單詞首字母下標,v單詞值]
             4.strcmp($str1,$str2);//按ASCII碼比較 str1>str2 則返回1 相等返回0 <返回-1  strcasecmp不區分大小寫的比較
             5.strnatcmp($str1,$str2);//按自然數的排序比較,上邊的比較10<2;本函數比較10>2,按自然數大小來的
                 strcasecmp($str1,$str2);strnatcasecmp//以上4個函數,$str1,$str2比較,【返回值:相等0,小於-1,大於1】
             6. number_format(10000[,2]);        //==》10,000.00        把第一個參數格式化,保留2位小數
             7. strlen($string);成功則返回字符串 $string 的長度
             8. mb_strlen($string,'utf8');//獲取字符串$string長度,多字節的字符被計爲 1。  

        文本處理類
            1.strtoupper($str)//字母全轉爲大寫【返回全大寫字符串】
            2.strtolower()//字母全轉爲小寫【返回全小寫字符串】
            3.strtotime('2015-10-10 10:10:10');//指定時間轉換爲時間戳【返回時間戳】
            4.str_pad($str,length,[---,STR_PAD_BOTH]); //在$str的兩邊填補“---“,注意,length若小於$str長度,不填補    
            5.trim($str[,"a",STR_PAD_BOTH])// 去除兩邊/左/右的空白或"a",默認是空白,或自定義字符
            6.floatval("123.45aa")//=》獲取變量的浮點值【123.45】
            7.ucfirst()//整個$str首字母大寫
            8.ucword()//$str每個單詞首字母大寫

        HTML類處理
            1.htmlspecialchars($str)//函數把【預定義字符】轉換爲【 HTML 實體】,&轉換成&
              htmlspecialchars_decode($str);//把【HTML實體】轉換成【預定義字符】,&轉換成&
            2.htmlentities($str);,函數把【預定義字符】轉換爲【 HTML 實體】,&轉換成&,有亂碼問題,注意第二第三個參數,若編碼不正確,會在實體化時把信息丟失
               html_entity_decode($str)////把【HTML實體】轉換成【預定義字符】,&轉換成&,  > 轉成 <
            3.addslashes($html);               //添加轉義字符“/”
               stripslashes($html);                 //刪除轉義字符“/”
            4.strip_tags($html);                     //去除HTML標籤
            5.nl2br($str)                                //在$str中的換行/n前插入<br>,因爲\n在源碼可以換行,但是在瀏覽器窗口不行,有這個就可以
            6.iconv( from_charset ; to_charset,$str);        //轉化字符格式     $file_name = iconv("gb2312","utf-8",$file_name);



正則函數[原則,能用字符串函數解決不用正則,速度問題]
        字符串的匹配查找
            1.preg_match($pattern,$subject,$arr);//按正則$pattern處理$subject,第一次匹配結果返回到數組中【函數的返回值爲匹配次數】
            2.preg_match_all($pattern,$subject,$arr)//按正則$pattern處理$subject,全部匹配結果返回到數組中【函數的返回值爲匹配次數】
            3.strstr($str,"@"[,true]);
            4.strpos,strrpos,substr($str,position)//聯合使用
         字符串的替換
            1.preg_replace($pattenr,$replace,$str);//【強大的字符串處理函數】
                        在$str中,把$parrern匹配的值替換成$replcae【返回值爲處理後的字符串】
            2.str_replace($str,"aaa","bbb");//把$str中的aaa換成bbb
         字符串的分割和鏈接
            1.preg_split($pattern,$str);通過一個正則表達式分隔字符串【返回值爲數組】                        
                        舉例:$keywords = preg_split("/[\s,]+/", "hypertext language, programming");
            結果Array([0] => hypertext,[1] => language[2] => programming)
            2.explode(",",$str[,$limit_num]);//把$str按照","分割成一個數組[可選參數爲返回數組的元素個數]【返回一個分割後的數組】
            3.impolde("+",$arr);//把$arr裏的元素按照“+”鏈接成一個字符串
         

文件處理函數
     [$file=c://php/index.php]
   基礎函數
        1.file_exists($file)//文件是否存在,【true/false】
        2.filesize($file)  //返回文件的大小【大小字節/出錯false】
        3.is_readale($file)//是否可讀【返回bool】
        4.is_writeable($file)//是否可寫【返回bool】
        5.is_executable($file)//是否可執行【返回bool】
        6.filectime($file)//文件創建時間【時間戳】
        7.filemtime($file)//文件修改時間【時間戳】
        8.fileatime($file)//文件訪問時間【時間戳】
        9.stat($file)//返回文件的大部分信息【文件信息數組】

  目錄的基本操作 
        1.basename($file)//返回文件名,index.php
        2.dirname($file)//返回文件的路徑,c://php/
        3.pathinfo($file)//返回該文件路徑的所有信息  ["dirname"目錄名] ["basename"文件名] ["extension"文件後綴]
      
    目錄複製,刪除,統計大小使用的總結:
        本質:依靠遞歸思想,對目錄的的循環遍歷,通過每一個文件的操作,得出結果
        函數:
                複製:copy($org,$to);mkdir()
                刪除:unlink($file);mrdir();
                統計大小:filesize($file)
     遍歷目錄
        1.opendir($file)//打開一個目錄,參數爲目錄名或目錄路徑【返回資源型的目錄句柄$dir_handle,無權限返false】
        2.readdir($dir_handle);//讀取目錄,參數爲目錄句柄,while,返回當前指向對象的名字,目錄指針後移【返回filename,沒有是返false】
        3.closedir($dir_handle)//關閉打開的目錄
        4.rewinddir($dir_handle) //倒回目錄句柄,將目錄指針重置到目錄開始    

文件的基本操作
      1.fopen($fileName,"模式字符r,w,x")//打開一個文件,【返回值爲資源型$handle】
      2.fclose($handle)    //關閉打開的文件【返回BOOL】
      3.fwrite($handle,"$data")//把$data寫入$handle文件,先清空後寫入,【成功返回$handle,失敗返回false】
      4.file_put_contents($filename,$data);//它是上邊三個合起來的效果
      5.file_get_contents($filename)//讀取文件裏的信息【返回字符串】
      6.flock($handle,$operation)    //用$operation鎖定文件$handle
        
      1.copy($file1,$file2);//賦值$file1,形成$file2【返回BOOL】
      2.unlink($file);//刪除$file文件【返回BOOL】
      3.rename($file1,$file_new_name);//重命名【返回BOOL】

   文件的上傳
       1.is_upload_file($_FILES['file']['tmp_name']) //檢查是否合法
       2.move_upload_file($_FILES['file']['tmp_name'],$url); //上傳合法文件到$url
      注意:html:form: method="post" ;enctype="multipart/form-data"
   文件下載
         header('content-disposition:attachment;filename='.basename($filename));//表示附件方式下載
         header('content-length:'.filesize($filename));
         readfile($filename);

   

SQL函數
        1.mysql_connect('localhost',"root","root");//連接誒數據庫
        2.mysql_select_db('data',$conn);//選擇數據庫名
        3.mysql_query('set names utf8');//設置編碼
    
        4.mysql_affect_array();//試返回值爲關聯/索引數組
        5.mysql_affect_row();//返回索引數組
        6.mysql_affect_assoc();//返回關聯數組

        7.mysql_num_rows();//返回上一次select的查詢語句條數
        8.mysql_affected_rows();//返回上一次insert,update,delete的數據條數

        9.mysql_close();//關閉數據庫

數學函數
    1.ceil()//向上取整
    2.floor()//向下取整
    3.round();//四捨五入
    4.abs();//取絕對值
    5.rand(10,100)//隨機取值
    6.mt_rand(10,100)//隨機取值,算法不同,速度更快
    7.fmod()//返回除法浮點形餘數
    8.max(int/$arr)//取最大值
    9.min(int/$arr)//取最小值
    10.pow(1024,2)//返回1021的2次冪

時間函數
1.date_default_timezone_set()('PRC');//設置時區爲中國
   date.timezone ="PRC";//PHP.INI
2.time();//默認獲取當前時間,【返回時間戳格式】
3.micritime();//獲取當前時間【返回毫秒的時間戳】
4.mktime(H,i,s,m,d,Y)//指定時間轉爲時間戳,參數爲空的時候作用與time()相同【返回時間戳格式】
5.strtotime('2015-10-10 10:10:10');//指定時間轉換爲時間戳【返回時間戳】
6.date("Y-m-d H:i:s",time());//轉換時間戳爲日期格式【返回目標格式的字符串】
7.getdate()//獲取當前時間,【返回一個數組,參數年,月,日等都有】

URL處理函數
1.urlencode($url)//對該URL進行編碼;原因:防止亂碼,解決空格的呢個字符不能傳遞問題,form也是此編碼格式傳遞
2.urldecode($url)//對該URL進行解碼
3.parse_url($url)//返回該URL的所有信息,[scheme協議][host域名] [path路徑][query參數]  【返回含信息的數組】
   pathinfo($url)//["dirname"目錄名] ["basename"文件名] ["extension"文件後綴]【返回含信息的數組,下標不同】
4.get_meta_tags($url)//獲取該頁面的所有META標籤【返回關聯數組】


JSON
1.json_encode($data);//對變量進行JSON編碼
2.json_decode($data)//對JSON格式的字符串進行解碼
3.json_last_error();//返回最後一次反生的錯誤

其他函數
sleep(10)//腳本執行到這裏後,延遲10秒繼續執行
serialize()//返回字符串,此字符串包含了表示 value 的字節流,可以存儲於任何地方。
unserialize()//對單一的已序列化的變量進行操作,將其轉換回 PHP 的值。
      當序列化對象時,PHP 將試圖在序列動作之前調用該對象的成員函數 __sleep()。這樣就允許對象在被序列化之前做任何清除操作。類似的,當使用 unserialize() 恢復對象時, 將調用 __wakeup() 成員函數。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章