展示不相鄰的資料

來源:互聯網
上載者:User
顯示不相鄰的資料
本帖最後由 lazygc520 於 2014-08-05 14:02:30 編輯

已知$arrs,

array (
0 =>
array (
'pono' => 'a',
'no' => '4711',
),
1 =>
array (
'pono' => 'a',
'no' => '4714',
),
2 =>
array (
'pono' => 'b',
'no' => '4714',
),
3 =>
array (
'pono' => 'b',
'no' => '4715',
),
4 =>
array (
'pono' => 'c',
'no' => '4715',
),
5 =>
array (
'pono' => 'c',
'no' => '4716',
),
)


現將同pono的資料合併,得:

$tmp=array();
$data=array();
$i=0;
foreach($arrs as $key=>$arr){
if(!empty($tmp) && array_key_exists($arr['pono'],$tmp)){
$key=$tmp[$arr['pono']];
$arr_no=explode(',',$data[$key]['no']);
if(!in_array($arr['no'],$arr_no)) $data[$key]['no'].=','.$arr['no'];
}else{
$tmp[$arr['pono']]=$i;
$data[$i++]=$arr;
}
}
print_r($data);

//得到結果:
Array
(
[0] => Array
(
[pono] => a
[no] => 4711,4714
)

[1] => Array
(
[pono] => b
[no] => 4714,4715
)

[2] => Array
(
[pono] => c
[no] => 4715,4716
)
)


現在想求僅顯示不相鄰的no,如例中的項:
[0] => Array
(
[pono] => a
[no] => 4711,4714
)

請問怎麼求?
------解決方案--------------------

$arrs = array (
0 =>
array (
'pono' => 'a',
'no' => '4711',
),
1 =>
array (
'pono' => 'a',
'no' => '4714',
),
2 =>
array (
'pono' => 'b',
'no' => '4714',
),
3 =>
array (
'pono' => 'b',
'no' => '4715',
),
4 =>
array (
'pono' => 'c',
'no' => '4715',
),
5 =>
array (
'pono' => 'c',
'no' => '4716',
),
);


$tmp=array();
$data=array();
$i=0;
foreach($arrs as $key=>$arr){
if(!empty($tmp) && array_key_exists($arr['pono'],$tmp)){
$key=$tmp[$arr['pono']];
$arr_no=explode(',',$data[$key]['no']);
if(!in_array($arr['no'],$arr_no)) $data[$key]['no'].=','.$arr['no'];
}else{
$tmp[$arr['pono']]=$i;
$data[$i++]=$arr;
}
}
print_r($data);

$result = array();

foreach($data as $val){
list($a, $b) = explode(',', $val['no']);
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.