ホームページ  >  記事  >  バックエンド開発  >  配列の結合を解決する

配列の結合を解決する

WBOY
WBOYオリジナル
2016-06-23 13:50:59790ブラウズ

配列 ( [59] =>aa [17] => bb [18] =>cc [69] => dd [21] =>ee [22] => ss [23] => ; 配列 ([0] => 1a[1] =>2a[2] => 3a [3] =>4a [4] => 55 ) [24] =>vv [26] = > va [43] => 配列 ( [0] => 道路 [1] => シアン [2] => ゴミ [3] => 光 [4] => 速度 [5 ] = > デン [6] => その後 ) [53] => 995 )[1] => 配列 ( [59] =>aa [17] => bb [18 ] =>cc [69] =>dd [21] =>ss [23] =>2a [2 ] => 3a [3] => 4a [4] => vv [26] => 配列 ( [0] =>道 [ 1] => ゴミ [3] => スピードランプ [6] => > 元 [ 54] => 995 )
最後の次元を結合するには?
トラバーサル中にマージするために foreach を使用していますか?データが多すぎると固まってしまうのでしょうか?


ディスカッションへの返信 (解決策)

マージとはどういう意味ですか?どれがどれにマージしますか?

統合とはどういう意味ですか?どれがどれにマージしますか?


配列 ([59] =>aa [17] =>bb [18] =>cc [69] =>dd [21] =>ee [22] =>ss [23] = > 配列 ( [0] => 1a[1] => 2a[2] => 3a [3] => 4a [4] => 55 ) [24] =>vv [26] => va [43] => 配列 ( [0] => 道路 [1] => 方向 [2] => ゴミ [3] => 光 [4] => 速度[ 5] => デン [6] => ) [53] => 995 )[1] => 配列 ( [59] =>aa [17] => bb [ 18] =>cc [69] => dd [21] => ss [23] => 配列 ( [0] => 1a[1] => 2a[ 2] => 3a [3] => 4a [4] => 55 ) [24] => vv [26] => 配列 ( [0] => ; 道[1] => ゴミ [3] => スピードランプ [6] => => 元 [54] => 995 )
たとえば [23] とマージします => 2a,3a,4a,55....

foreach($arr as $k=>$v){        if(is_array($v)) $arr[$k] = implode(',', $v);}print_r($arr);

foreach($arr as $k=>$v){        if(is_array($v)) $arr[$k] = implode(',', $v);}print_r($arr);


Ifそれは三次元配列のマージです 三次元ではこんな感じですか?
foreach($arr as $k=>$v){foeach($v as $key=>$val){        if(is_array($val)) $v[$key] = implode(',', $val);}}

必ずしもそうではありません。 ] = implode(',', $val);

$arr[$k][$key] = implode(',', $val); に変更します


そして、$v がそうでない場合は、エラーが報告されます

いいえ、はい、foeach($v as... を入力する前に、$v が配列であることを判断する必要があります。

あなたが言ったように、私は失敗しました

array(

[9]=> 配列([77]=>bb[8] 8]=>cc) は bb,cc[10]=>44 にマージされました
)
..... ... ......
)
......................
最終的な実装は 2 次元配列に変換されます。 。 。次に、それを Excel にエクスポートします
最後の配列の練習では頭が痛くなり、まだ完全にマスターできていません

应该这样写

$a = array(  0 => array(    8 => 'aa',    9 => array(      77 => 'bb',      88 => 'cc',    ),    10 => 44,  ),);$a = dimension_reduction($a); //执行一次降一次维print_r($a);$a = dimension_reduction($a);print_r($a);//降维function dimension_reduction($ar) {  $flag = 1;  foreach($ar as $k=>$v) {    if(is_array($v)) {      $flag = 0;      $ar[$k] = dimension_reduction($v);    }  }  if($flag) return join(',', $ar);  return $ar;}
Array
(
    [0] => Array
        (
            [8] => aa
            [9] => bb,cc
            [10] => 44
        )

)
Array
(
    [0] => aa,bb,cc,44
)

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。