-2

PHP Sqlの結果があり、表は次のようになります。

次のように表示されます。

[id]|test1|data|voice
1|0|0|-1
2|0|1|0
3|0|-2|-1

配列の Print_r は次のようになります。


Array
(
[2] => Array
    (
        [0] => Array
            (
                [test1] => 0
                [data] => 0
                [mobile] => -1
            )

    )

[3] => Array
    (
        [0] => Array
            (
                [test1] => 0
                [data] => 1
                [voice] => 0
            )

    )

[4] => Array
    (
        [0] => Array
            (
                [test1] => 0
                [data] => -2
                [voice] => -1
            )

    )

配列が次のようになるように配列を操作したい:

Array (
    [0] => Array
    ( 
            [name] =>  test1
            [val] => array(0 , 0, 0) 
    )
    [1] => Array 
    (
            [name] => data
            [val] => array(0, 1, -2)
    )
    [2] => Array
    (
            [name] => voice
            [val] => array(-1,0, 0)
    )
4

2 に答える 2

1

ソース配列名を $Arr と考えて、以下のコードを試してください

foreach($Arr as $valArr)
{
    $index = 0;
    foreach($valArr[0] as $k => $v)
    {
        $newArr[$index]["name"] = $k;
        $newArr[$index]["val"][ ] = $v;
        $index++;
    }
}

echo "<pre>"; print_r($newArr);
于 2013-01-23T06:15:04.743 に答える
0

use this and do modifications if neded

SELECT *
FROM `table_name`
GROUP BY `test1` , `data` , `voice`
LIMIT 0 , 30
于 2013-01-23T06:09:31.420 に答える