php中Array數(shù)組函數(shù)用法詳解
來源:程序員人生 發(fā)布時間:2013-11-26 04:38:28 閱讀次數(shù):3351次
在php中數(shù)組是一種特殊的數(shù)據(jù)類型,同時php也給我們提供了大量的數(shù)組操作函數(shù),從而讓我們在對數(shù)組操作時感覺無壓力啊,下面我總結(jié)了php array數(shù)組入門筆記分享給各位。
簡介:本次介紹的是PHP手冊中用來對數(shù)組進行各種操作的系統(tǒng)函數(shù),可以說數(shù)組在PHP中有重要的作用,因此函數(shù)也是灰常多,下面天涯把最常用的進行詳細(xì)說明。
array_change_key_case — 返回字符串鍵名全為小寫或大寫的數(shù)組
array array_change_key_case ( array $input [, int $case ] )
$case 可為 CASE_UPPER 或 CASE_LOWER(默認(rèn))
代碼如下:
- <?php
- $phpha = array('Home'=>'http://www.phpfensi.com', 'Blog'=>'http://www.phpfensi.com');
- $phpha_upper = array_change_key_case($phpha, CASE_UPPER);
- $phpha_lower = array_change_key_case($phpha, CASE_LOWER);
- print_r($phpha_upper);
- print_r($phpha_lower);
- ?>
-
- Array
- (
- [HOME] => http:
- [BLOG] => http:
- )
- Array
- (
- [home] => http:
- [blog] => http:
- )
array_chunk — 將一個數(shù)組分割成多個
array array_chunk ( array $input , int $size [, bool $preserve_keys ] )
array_chunk() 將一個數(shù)組分割成多個數(shù)組,其中每個數(shù)組的單元數(shù)目由 size 決定。最后一個數(shù)組的單元數(shù)目可能會少幾個。得到的數(shù)組是一個多維數(shù)組中的單元,其索引從零開始。
將可選參數(shù) preserve_keys 設(shè)為 TRUE,可以使 PHP 保留輸入數(shù)組中原來的鍵名。如果你指定了 FALSE,那每個結(jié)果數(shù)組將用從零開始的新數(shù)字索引,默認(rèn)值是 FALSE,代碼如下:
- <?php
- $input_array = array('a', 'b', 'c', 'd', 'e');
- print_r(array_chunk($input_array, 2));
- print_r(array_chunk($input_array, 2, TRUE));
- ?>
-
- Array
- (
- [0] => Array
- (
- [0] => a
- [1] => b
- )
-
- [1] => Array
- (
- [0] => c
- [1] => d
- )
-
- [2] => Array
- (
- [0] => e
- )
-
- )
- Array
- (
- [0] => Array
- (
- [0] => a
- [1] => b
- )
-
- [1] => Array
- (
- [2] => c
- [3] => d
- )
-
- [2] => Array
- (
- [4] => e
- )
-
- )
array_combine — 創(chuàng)建一個數(shù)組,用一個數(shù)組的值作為其鍵名,另一個數(shù)組的值作為其值
array array_combine ( array $keys , array $values )
返回一個 array,用來自 keys 數(shù)組的值作為鍵名,來自 values 數(shù)組的值作為相應(yīng)的值。
如果兩個數(shù)組的單元數(shù)不同或者數(shù)組為空時返回 FALSE,代碼如下:
- <?php
- $key = array('Home', 'Blog');
- $key2 = array('Home', 'Blog', 'BBS');
- $phpha = array('http://www.phpfensi.com', 'http://www.phpfensi.com');
- $phpha_combine = array_combine($key, $phpha);
- $phpha_combine_wrong = array_combine($key2, $phpha);
- print_r($phpha_combine);
- print_r($phpha_combine_wrong);
- ?>
-
- Array
- (
- [Home] => http:
- [Blog] => http:
- )
可以看到第二次array_combine()報錯了,指出了2個數(shù)組的成員數(shù)量不相等.
Warning: Both parameters should have an equal number of elements in F:Program FilesPHPNOWhtdocsindex.php on line 31
array_count_values — 統(tǒng)計數(shù)組中所有的值出現(xiàn)的次數(shù)
array array_count_values ( array $input )
array_count_values() 返回一個數(shù)組,該數(shù)組用 input 數(shù)組中的值作為鍵名,該值在 input 數(shù)組中出現(xiàn)的次數(shù)作為值,代碼如下:
- <?php
- $phpha = array('hello', 'world', 'tianya', 'hello', 'world');
- $phpha_result = array_count_values($phpha);
- print_r($phpha_result);
- ?>
-
- Array
- (
- [hello] => 2
- [world] => 2
- [tianya] => 1
- )
array_diff — 計算數(shù)組的差集
array_diff_key — 使用鍵名比較計算數(shù)組的差集
array_diff_ukey — 用回調(diào)函數(shù)對鍵名比較計算數(shù)組的差集
array_diff_assoc — 帶索引檢查計算數(shù)組的差集
array_diff_uassoc — 用用戶提供的回調(diào)函數(shù)做索引檢查來計算數(shù)組的差集
代碼如下:
-
-
- <?php
- $array1 = array("a" => "green", "red", "blue", "red");
- $array2 = array("b" => "green", "yellow", "red");
- $result = array_diff($array1, $array2);
- print_r($result);
- ?>
-
- Array
- (
- [1] => blue
- )
-
- <?php
- $array1 = array('blue' => 1, 'red' => 2, 'green' => 3, 'purple' => 4);
- $array2 = array('green' => 5, 'blue' => 6, 'yellow' => 7, 'cyan' => 8);
- print_r(array_diff_key($array1, $array2));
- ?>
-
- Array
- (
- [red] => 2
- [purple] => 4
- )
-
- <?php
- $array1 = array ("a" => "green", "b" => "brown", "c" => "blue", "red");
- $array2 = array ("a" => "green", "yellow", "red");
- print_r(array_diff_assoc($array1, $array2));
- ?>
-
- Array
- (
- [b] => brown
- [c] => blue
- [0] => red
- )
array_fill — 用給定的值填充數(shù)組
array_fill_keys — Fill an array with values, specifying keys
array_filter — 用回調(diào)函數(shù)過濾數(shù)組中的單元
代碼如下:
- <?php
- function func_check($i){
- return $i > 3 ? TRUE : FALSE;
- }
- $array1 = array(2, 3, 5, 6);
- $array2 = array(NULL, '', 'hello');
- $array3 = array_filter($array1, 'func_check');
- $array4 = array_filter($array2);
-
-
- print_r($array3);
-
-
- print_r($array4);
- ?>
-
- Array
- (
- [2] => 5
- [3] => 6
- )
- Array
- (
- [2] => hello
- )
array_flip — 交換數(shù)組中的鍵和值
代碼如下:
-
- <?php
- $trans = array("a" => 1, "b" => 1, "c" => 2);
- $trans = array_flip($trans);
- print_r($trans);
- ?>
-
- Array
- (
- [1] => b
- [2] => c
- )
array_intersect — 計算數(shù)組的交集
array_intersect_assoc — 帶索引檢查計算數(shù)組的交集
array_intersect_uassoc — 帶索引檢查計算數(shù)組的交集,用回調(diào)函數(shù)比較索引
array_intersect_key — 使用鍵名比較計算數(shù)組的交集
array_intersect_ukey — 用回調(diào)函數(shù)比較鍵名來計算數(shù)組的交集
代碼如下:
- <?php
- $array1 = array("a" => "green", "red", "blue");
- $array2 = array("b" => "green", "yellow", "red");
- $result = array_intersect($array1, $array2);
- print_r($result);
- ?>
-
- Array
- (
- [a] => green
- [0] => red
- )
-
- <?php
- $array1 = array("a" => "green", "b" => "brown", "c" => "blue", "red");
- $array2 = array("a" => "green", "yellow", "red");
- $result = array_intersect_assoc($array1, $array2);
- print_r($result);
- ?>
-
- Array
- (
- [a] => green
- )
array_keys — 返回數(shù)組中所有的鍵名
array_values — 返回數(shù)組中所有的值
array_key_exists — 檢查給定的鍵名或索引是否存在于數(shù)組中
代碼如下:
- <?php
- $phpha = array('blog'=>'http://www.phpfensi.com', 'home'=>'http://phpfensi.com');
- echo array_key_exists('blog', $phpha) ? 'Exist' : 'Not Exist';
- echo '<br />';
- echo array_key_exists('Blog', $phpha) ? 'Exist' : 'Not Exist';
- print_r(array_keys($phpha));
- print_r(array_values($phpha));
- ?>
-
-
- Exist
- Not Exist
- Array
- (
- [0] => blog
- [1] => home
- )
- Array
- (
- [0] => http:
- [1] => http:
- )
array_map — 將回調(diào)函數(shù)作用到給定數(shù)組的單元上
代碼如下:
-
- <?php
- function func_add($i){
- return $i+1;
- }
- $array1 = array(1, 3, 5, 7);
- print_r(array_map('func_add', $array1));
- ?>
-
- Array
- (
- [0] => 2
- [1] => 4
- [2] => 6
- [3] => 8
- )
array_merge — 合并一個或多個數(shù)組
array_merge_recursive — 遞歸地合并一個或多個數(shù)組
代碼如下:
- <?php
- $array1 = array('hello', 'home'=>'phpfensi.com');
- $array2 = array('world', 'home'=>'www.phpfensi.com');
- print_r(array_merge($array1, $array2));
- ?>
-
-
- Array
- (
- [0] => hello
- [home] => www.phpfensi.com
- [1] => world
- )
array_pop — 將數(shù)組最后一個單元彈出(出棧)
array_push — 將一個或多個單元壓入數(shù)組的末尾(入棧)
代碼如下:
- <?php
- $stack = array("orange", "banana");
- array_push($stack, "apple", "raspberry");
- print_r($stack);
- array_pop($stack);
- print_r($stack);
- ?>
-
- Array
- (
- [0] => orange
- [1] => banana
- [2] => apple
- [3] => raspberry
- )
- Array
- (
- [0] => orange
- [1] => banana
- [2] => apple
- )
array_shift — 將數(shù)組開頭的單元移出數(shù)組
array_unshift — 在數(shù)組開頭插入一個或多個單元
代碼如下:
- <?php
- $stack = array("orange", "banana");
- array_shift($stack);
- print_r($stack);
- array_unshift($stack, "apple", "raspberry");
- print_r($stack);
- ?>
-
- Array
- (
- [0] => banana
- )
- Array
- (
- [0] => apple
- [1] => raspberry
- [2] => banana
- )
sort — 對數(shù)組排序
rsort — 對數(shù)組逆向排序
asort — 對數(shù)組進行排序并保持索引關(guān)系
arsort — 對數(shù)組進行逆向排序并保持索引關(guān)系
ksort — 對數(shù)組按照鍵名排序
krsort — 對數(shù)組按照鍵名逆向排序
代碼如下:
- <?php
- $fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
- asort($fruits);
- print_r($fruits);
- arsort($fruits);
- print_r($fruits);
- ksort($fruits);
- print_r($fruits);
- krsort($fruits);
- print_r($fruits);
- ?>
-
- Array
- (
- [c] => apple
- [b] => banana
- [d] => lemon
- [a] => orange
- )
- Array
- (
- [a] => orange
- [d] => lemon
- [b] => banana
- [c] => apple
- )
- Array
- (
- [a] => orange
- [b] => banana
- [c] => apple
- [d] => lemon
- )
- Array
- (
- [d] => lemon
- [c] => apple
- [b] => banana
- [a] => orange
- )
compact — 建立一個數(shù)組,包括變量名和它們的值
extract — 從數(shù)組中將變量導(dǎo)入到當(dāng)前的符號表
代碼如下:
- <?php
- $home = 'phpfensi.com';
- $blog = 'www.phpfensi.com';
- $result = compact('home', 'blog');
- print_r($result);
- ?>
-
- Array
- (
- [home] => http:
- [blog] => http:
- )
- <?php
-
- if(isset($home)) unset($home);
- if(isset($blog)) unset($blog);
- $phpha = array('home'=>'http://111cn.net', 'blog'=>'http://www.111cn.net');
- extract($phpha);
- echo $home . '<br />' . $blog;
- ?>
-
- http:
- http:
in_array — 檢查數(shù)組中是否存在某個值
代碼如下:
- <?php
- $phpha = array('home', 'blog');
- if(in_array('home', $phpha)){
- echo 'home is in $phpha';
- }else{
- echo 'home is not in $phpha';
- }
- echo '<br />';
- if(in_array('Home', $phpha)){
- echo 'Home is in $phpha';
- }else{
- echo 'Home is not in $phpha';
- }
- ?>
-
-
- home is in $phpha
- Home is not in $phpha
list — 把數(shù)組中的值賦給一些變量
代碼如下:
- <?php
- $phpha = array('http://phpfensi.com', 'http://www.phpfensi.com');
- list($home, $blog) = $phpha;
- echo $home . '<br />' . $blog;
- ?>
-
- http:
- http:
array_multisort — 對多個數(shù)組或多維數(shù)組進行排序
array_pad — 用值將數(shù)組填補到指定長度
array_product — 計算數(shù)組中所有值的乘積
array_rand — 從數(shù)組中隨機取出一個或多個單元
array_reduce — 用回調(diào)函數(shù)迭代地將數(shù)組簡化為單一的值
array_reverse — 返回一個單元順序相反的數(shù)組
array_search — 在數(shù)組中搜索給定的值,如果成功則返回相應(yīng)的鍵名
array_slice — 從數(shù)組中取出一段
array_splice — 把數(shù)組中的一部分去掉并用其它值取代
array_sum — 計算數(shù)組中所有值的和
array_udiff_assoc — 帶索引檢查計算數(shù)組的差集,用回調(diào)函數(shù)比較數(shù)據(jù)
array_udiff_uassoc — 帶索引檢查計算數(shù)組的差集,用回調(diào)函數(shù)比較數(shù)據(jù)和索引
array_udiff — 用回調(diào)函數(shù)比較數(shù)據(jù)來計算數(shù)組的差集
array_uintersect_assoc — 帶索引檢查計算數(shù)組的交集,用回調(diào)函數(shù)比較數(shù)據(jù)
array_uintersect_uassoc — 帶索引檢查計算數(shù)組的交集,用回調(diào)函數(shù)比較數(shù)據(jù)和索引
array_uintersect — 計算數(shù)組的交集,用回調(diào)函數(shù)比較數(shù)據(jù)
array_unique — 移除數(shù)組中重復(fù)的值
array_walk_recursive — 對數(shù)組中的每個成員遞歸地應(yīng)用用戶函數(shù)
array_walk — 對數(shù)組中的每個成員應(yīng)用用戶函數(shù)
array — 新建一個數(shù)組
count — 計算數(shù)組中的單元數(shù)目或?qū)ο笾械膶傩詡€數(shù)
current — 返回數(shù)組中的當(dāng)前單元
next — 將數(shù)組中的內(nèi)部指針向前移動一位
each — 返回數(shù)組中當(dāng)前的鍵/值對并將數(shù)組指針向前移動一步
end — 將數(shù)組的內(nèi)部指針指向最后一個單元
key — 從關(guān)聯(lián)數(shù)組中取得鍵名
natcasesort — 用“自然排序”算法對數(shù)組進行不區(qū)分大小寫字母的排序
natsort — 用“自然排序”算法對數(shù)組排序
uasort — 使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序并保持索引關(guān)聯(lián)
uksort — 使用用戶自定義的比較函數(shù)對數(shù)組中的鍵名進行排序
usort — 使用用戶自定義的比較函數(shù)對數(shù)組中的值進行排序
pos — current 的別名
prev — 將數(shù)組的內(nèi)部指針倒回一位
range — 建立一個包含指定范圍單元的數(shù)組
reset — 將數(shù)組的內(nèi)部指針指向第一個單元
shuffle — 將數(shù)組打亂
sizeof — count 的別名
生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對您的學(xué)習(xí)有所幫助,可以手機掃描二維碼進行捐贈