導語:需求已搞定,只要遇到陣列,我們第一個想到的除了現成的PHP方法之外,就是迴圈,不管是foreach還是for,下面就由小編為大家介紹一下PHP二維去重演算法的方法,歡迎大家閱讀!
需求
現在有下面一組二維陣列:
array(8) {
[0]=>
array(2) {
["name"]=>
string(4) "name"
["value"]=>
string(6) "青葉"
}
[1]=>
array(2) {
["name"]=>
string(5) "phone"
["value"]=>
string(11) "13812341234"
}
[2]=>
array(2) {
["name"]=>
string(12) "fileds_507[]"
["value"]=>
string(12) "我是青葉"
}
[3]=>
array(2) {
["name"]=>
string(12) "fileds_508[]"
["value"]=>
string(6) "合肥"
}
[4]=>
array(2) {
["name"]=>
string(12) "fileds_509[]"
["value"]=>
string(3) "男"
}
[5]=>
array(2) {
["name"]=>
string(12) "fileds_510[]"
["value"]=>
string(6) "足球"
}
[6]=>
array(2) {
["name"]=>
string(12) "fileds_510[]"
["value"]=>
string(6) "棒球"
}
[7]=>
array(2) {
["name"]=>
string(12) "fileds_511[]"
["value"]=>
string(16) "2016-12-15T11:15"
}
}
需要將處於第二維鍵名為name,其值相同的陣列的value合併,形成一個新的`陣列。
比如上面程式碼中的name為fileds_510的兩個二維陣列,就應該合併為一個值為足球,棒球的陣列。
思路
提到陣列,再PHP中我們首先想到了迴圈,那麼這裡顯然比較適合使用for迴圈處理,與氣泡排序相似,一個個比較,最好處理。
程式碼
程式碼如下:
$public_info = 陣列;
for ($i=0;$i
for ($j=$i+1;$j
if ($public_info[$j]['name'] == $public_info[$i]['name']) {
$public_info[$i]['value'] .= ',' . $public_info[$j]['value'];
unset($public_info[$j]);
}
}
}
執行結果:
array(7) {
[0]=>
array(2) {
["name"]=>
string(4) "name"
["value"]=>
string(6) "青葉"
}
[1]=>
array(2) {
["name"]=>
string(5) "phone"
["value"]=>
string(11) "13812341234"
}
[2]=>
array(2) {
["name"]=>
string(12) "fileds_507[]"
["value"]=>
string(12) "我是青葉"
}
[3]=>
array(2) {
["name"]=>
string(12) "fileds_508[]"
["value"]=>
string(6) "合肥"
}
[4]=>
array(2) {
["name"]=>
string(12) "fileds_509[]"
["value"]=>
string(3) "男"
}
[5]=>
array(2) {
["name"]=>
string(12) "fileds_510[]"
["value"]=>
string(13) "足球,棒球"
}
[7]=>
array(2) {
["name"]=>
string(12) "fileds_511[]"
["value"]=>
string(16) "2016-12-15T11:15"
}
}