PHP - Вложение массива из ответа API obj - PullRequest
0 голосов
/ 14 мая 2018

У меня большой ответ API объекта, я пытаюсь загрузить данные во вложенный массив, чтобы я мог работать с ним позже.Вот пример объекта, который я получаю от API.

SObject Object
(
    [type] => AggregateResult
    [fields] => stdClass Object
        (
            [expr0] => 12
            [Name] => Performance Reviews
            [Status] => Closed - Approved
            [expr1] => 30
        )

)
SObject Object
(
    [type] => AggregateResult
    [fields] => stdClass Object
        (
            [expr0] => 12
            [Name] => Performance Reviews
            [Status] => Closed - Attempted
            [expr1] => 11
        )

)
SObject Object
(
    [type] => AggregateResult
    [fields] => stdClass Object
        (
            [expr0] => 12
            [Name] => Performance Reviews
            [Status] => Closed - Contact Declined
            [expr1] => 13
        )

Как я уже сказал, цель состоит в том, чтобы иметь вложенный массив, который будет выглядеть примерно так:

Array
    (
        [January] => Array
        (
            [0] => Array
            (
                [0] => January
                [1] => Closed - Approved
                [2] => 28
            )
            [1] => Array
            (
                [0] => January
                [1] => Closed - Approved
                [2] => 28
            )
        )
    )

Вот мой код:

$query = 
     "SELECT CALENDAR_MONTH(closedDate), recordType.name,status,count(id) 
      FROM case 
      WHERE owner.name ='" . $SFName . "' AND recordType.name IN('DT Case','Performance Reviews') AND closedDate = LAST_N_MONTHS:6 
      GROUP BY CALENDAR_MONTH(closedDate),recordType.Name,status ORDER BY CALENDAR_MONTH(closedDate)";

    $counter     = 0;
    $mprArray    = array(); //instantiate our Array
    $response    = $mySforceConnection->query($query); 
    $queryResult = new QueryResult($response); 

    foreach ($queryResult->records as $case) { 
        //turn our query Result into an Obj
        $sObject    = new SObject($case);
        $recordType = $sObject->Name; 
        $status     = $sObject->Status;
        $month      = $sObject->expr0;
        $count      = $sObject->expr1;

        //this is a filter to weed out a portion of the cases.
        if ($recordType == "Performance Reviews") {
            foreach($sObject as $record) { 
                //change the month's number to a month's name
                $dateObj   = DateTime::createFromFormat('!m', $month);
                $monthName = $dateObj->format('F');
                // Create the nested array, it should end up looking like $mprArray[January]. 
                // This is a dynamic name since we're creating an array for each status that exists in performance Reviews
                $mprArray[$monthName] = array($monthName,$status,$count); 
                // Trying to append our nested array onto the $mprArray so we can work with it later.
                array_push($mprArray,$mprArray[$monthName]);
            }

        }
        //increase counter
        $counter = $counter++; 
    }

} catch (Exception $e) {
    print_r($mySforceConnection->getLastRequest());
    echo $e->faultstring;
}

Вместо вложенного массива только первый элемент в массиве называется «Январь», остальные именуются на основе счетчика, пока мы не перейдем к следующему месяцу.«Февраль», вот как это выглядит.

Array
(
    [January] => Array
        (
            [0] => January
            [1] => Closed - Contact Declined
            [2] => 15
        )

    [0] => Array
        (
            [0] => January
            [1] => Closed - Approved
            [2] => 28
        )
)

1 Ответ

0 голосов
/ 15 мая 2018

потому что array_push только вставляет данные в следующий индекс;Я чувствую, что вы должны использовать только $mprArray[$monthName][] = array($monthName,$status,$count);;и нет необходимости в array_push после этого

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...