PHP實(shí)現(xiàn)二維數(shù)組(或多維數(shù)組)轉(zhuǎn)換成一維數(shù)組的常見(jiàn)方法總結(jié)
本文實(shí)例總結(jié)了PHP實(shí)現(xiàn)二維數(shù)組(或多維數(shù)組)轉(zhuǎn)換成一維數(shù)組的常見(jiàn)方法。分享給大家供大家參考,具體如下:
假設(shè)有下面一個(gè)二維數(shù)組:
$user = array(
'0' => array('id' => 100, 'username' => 'a1'),
'1' => array('id' => 101, 'username' => 'a2'),
'2' => array('id' => 102, 'username' => 'a3'),
'3' => array('id' => 103, 'username' => 'a4'),
'4' => array('id' => 104, 'username' => 'a5'),
);
現(xiàn)在要轉(zhuǎn)換成一維數(shù)組,有兩種情況:
一種是將指定列轉(zhuǎn)換成一維數(shù)組,這在另一篇文章有總結(jié):PHP提取多維數(shù)組指定一列的方法總結(jié)。
現(xiàn)在我們重點(diǎn)講第二種情況,就是把所有的值都轉(zhuǎn)換成一維數(shù)組,而且鍵值相同不會(huì)被覆蓋,轉(zhuǎn)換后的一維數(shù)組是這樣的:
$result = array(100, 'a1', 101, 'a2', 102, 'a3', 103, 'a4', 104, 'a5');
主要有下面幾個(gè)方法。
1 array_reduce函數(shù)法
用array_reduce()函數(shù)是較為快捷的方法:
$result = array_reduce($user, function ($result, $value) {
return array_merge($result, array_values($value));
}, array())
因?yàn)閍rray_merge函數(shù)會(huì)把相同字符串鍵名的數(shù)組覆蓋合并,所以必須先用array_value取出值后再合并。
如果第二維是數(shù)字鍵名,如:
$user = array( 'a' => array(100, 'a1'), 'b' => array(101, 'a2'), 'c' => array(102, 'a3'), 'd' => array(103, 'a4'), 'e' => array(104, 'a5'), );
那么直接這樣就可以了:
$result = array_reduce($user, 'array_merge', array())
2 array_walk_recursive函數(shù)法
用array_walk_recursive()函數(shù)就非常靈活,可以把任意維度的數(shù)組轉(zhuǎn)換成一維數(shù)組。
$result = [];
array_walk_recursive($user, function($value) use (&$result) {
array_push($result, $value);
});
例如,下面這個(gè)多維數(shù)組:
$user4 = array(
'a' => array(100, 'a1'),
'b' => array(101, 'a2'),
'c' => array(
'd' => array(102, 'a3'),
'e' => array(103, 'a4'),
),
);
用這個(gè)方法后就變成:
$result = array(100, 'a1', 101, 'a2', 102, 'a3', 103, 'a4');
3 array_map函數(shù)法
用array_map和array_reduce函數(shù)的方法類似,如下:
$result = [];
array_map(function ($value) use (&$result) {
$result = array_merge($result, array_values($value));
}, $user);
只是需要多聲明一個(gè)空的$result數(shù)組。
另外,也可以用array_walk的方法,和foreach循環(huán)的方法,原理和上面一樣。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》及《PHP常用遍歷算法與技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
php實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)備份與還原類實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)備份與還原類,可實(shí)現(xiàn)針對(duì)MySQL數(shù)據(jù)庫(kù)的導(dǎo)入與導(dǎo)出功能,并且包含了針對(duì)數(shù)據(jù)庫(kù)操作時(shí)的加鎖與解鎖等功能,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12
php給一組指定關(guān)鍵詞添加span標(biāo)簽的方法
這篇文章主要介紹了php給一組指定關(guān)鍵詞添加span標(biāo)簽的方法,涉及php正則替換的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
PHP標(biāo)準(zhǔn)庫(kù)(PHP SPL)詳解
今天小編就為大家分享一篇關(guān)于PHP標(biāo)準(zhǔn)庫(kù)(PHP SPL)詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03
php heredoc和phpwind的模板技術(shù)使用方法小結(jié)
Heredoc技術(shù),在正規(guī)的PHP文檔中和技術(shù)書籍中一般沒(méi)有詳細(xì)講述,只是提到了這是一種Perl風(fēng)格的字符串輸出技術(shù)。但是現(xiàn)在的一些論壇程序,和部分文章系統(tǒng),都巧妙的使用heredoc技術(shù),來(lái)部分的實(shí)現(xiàn)了界面與代碼的準(zhǔn)分離,phpwind就是一個(gè)典型的例子。2008-03-03
php strrpos()與strripos()函數(shù)
以下是對(duì)php中的strrpos函數(shù)與strripos函數(shù)的用法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08
PHP7創(chuàng)建COOKIE和銷毀COOKIE的實(shí)例方法
在本篇文章里小編給大家整理的是關(guān)于PHP7創(chuàng)建COOKIE和銷毀COOKIE的實(shí)例方法,有需要的朋友們可以參考下。2020-02-02
PHP中echo,print_r與var_dump區(qū)別分析
這篇文章主要介紹了PHP中echo,print_r與var_dump區(qū)別分析,主要講述了三者的類型本質(zhì)及其操作數(shù)據(jù)類型的用法區(qū)別,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-09-09
調(diào)試一段PHP程序時(shí)遇到的三個(gè)問(wèn)題
調(diào)試一段PHP程序時(shí)遇到的三個(gè)問(wèn)題,學(xué)習(xí)php的朋友可以參考下。2012-01-01

