您好,登錄后才能下訂單哦!
PHP中array_map與array_column有什么關(guān)系?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
array_map()與array_column()用法如下:
array_map();將回調(diào)函數(shù)作用到給定數(shù)組的單元上
array_column();快速實現(xiàn):將二維數(shù)組轉(zhuǎn)為一維數(shù)組
array_column()函數(shù)格式為:
array array_column ( array $input , mixed $column_key [, mixed $index_key ] );
返回input數(shù)組中值為column_key的列; 如果指定了可選參數(shù)index_key,返回的數(shù)組中 對應(yīng)鍵 為input數(shù)組值index_key對應(yīng)的值。
示例代碼一:
$records = array( array( 'id' => 2135, 'first_name' => 'John', 'last_name' => 'Doe', ), array( 'id' => 3245, 'first_name' => 'Sally', 'last_name' => 'Smith', ), array( 'id' => 5342, 'first_name' => 'Jane', 'last_name' => 'Jones', ), array( 'id' => 5623, 'first_name' => 'Peter', 'last_name' => 'Doe', ) ); $first_names = array_column($records, 'first_name'); print_r($first_names);
輸出:
Array ( [0] => John [1] => Sally [2] => Jane [3] => Peter )
示例代碼二:
$last_names = array_column($records, 'last_name', 'id'); print_r($last_names);
輸出:
Array ( [2135] => Doe [3245] => Smith [5342] => Jones [5623] => Doe )
當(dāng)沒有array_column()函數(shù)情況下,
使用array_map()實現(xiàn)例一:
$a = array_map(function($element){ //$records作為參數(shù)傳入回調(diào)函數(shù) return $element['last_name']; //返回數(shù)組元素值的last_name對應(yīng)值 }, $records); //array_map返回數(shù)組,相當(dāng)于把每個$element['last_name']存入新數(shù)組,所以是新建的索引
使用foreach實現(xiàn)例一:
foreach($records as $v) { $b[] = $v['last_name']; }
使用foreach實現(xiàn)例二: $c = array(); foreach($records as $k=>$v) { $c += array($v['id']=>$v['last_name']); //使用+運算符, 以追加的形式(不改變原數(shù)組索引), 合并組裝的數(shù)組 } //若使用array_merge,數(shù)字鍵名將被重新編號
在取出的多條數(shù)據(jù)中,典型的二維數(shù)組,如果需要使用數(shù)據(jù)中單一的值與值對應(yīng)的情況,array_column()即可完成,但是面對較復(fù)雜的數(shù)組結(jié)構(gòu),foreach才能讓你更靈活,不過優(yōu)先使用系統(tǒng)函數(shù)總是首選的。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。