Итерация по объектам simplexml и добавление их - PullRequest
0 голосов
/ 12 января 2019

Я прошу прощения, если на это был ответ. Я искал решение и не мог ничего найти. Но я пытаюсь перебрать простой симплекс, полученный из вызова API. API не самый лучший, поэтому, когда дата пересекает полночь, это полностью исключает эти заказы. Таким образом, чтобы обойти это, я должен получить заказы на следующий день и затем выполнить foreach для заказов, затем я делаю if в дату, чтобы получить целевую дату. В каждом цикле я хочу, чтобы он брал объекты simplexml, помещал их в переменную и добавлял каждый новый, поэтому к концу у меня будет новый объект только с правильными датами.

Я пытался удалить определенные узлы, но это кажется гораздо более запутанным, чем просто их объединение в конце каждой итерации.

if (strtotime($thisFri) >= strtotime($today)) {
    $params = array(
        "shiftStart" => $thisFri . " 00:00:00",
        "shiftEnd" => $thisSat . "12:00:00",
        "status" => "filled"
    );
    $clearConnect->setParameters($params);
    $clearConnect->setResultType('xml');
    $shiftResult = $clearConnect->sendRequest('getOrders'); //gets orders
    $friShifts = simplexml_load_string($shiftResult); //puts the results in to xml
    foreach ($friShifts->order as $shift) { //iterates through each order
        $startLong = new DateTime($shift->shiftStartTime); //figuring out dates
        $start = $startLong->format('Y-m-d');
        $endLong = new DateTime($shift->shiftEndTime);
        $end = $endLong->format('Y-m-d');
        if ($start == $thisFri) { //if to run through all orders with proper start date

Это то место, где я нахожусь. $ friShifts - это симплексный файл, содержащий несколько заказов, которые выглядят следующим образом. Еще немного происходит после этого, но это в основном то, что я ищу. Я хочу, чтобы каждая итерация правильной даты помещалась в новый симплекс-файл, который затем выполнялся через другие мои функции.

SimpleXMLElement Object
(
    [orderId] => 3988445
    [status] => filled
    [shiftStartTime] => 2019-01-11T07:00:00
    [shiftEndTime] => 2019-01-11T15:30:00
    [tempId] => 57921
    [firstName] => SimpleXMLElement Object
        (
        )

    [lastName] => SimpleXMLElement Object
        (
        )

    [clientId] => 1543
    [clientName] => SimpleXMLElement Object
        (
        )

    [regionName] => SimpleXMLElement Object
        (
        )

    [orderSpecialty] => School
    [orderCertification] => SLP
    [floor] => SimpleXMLElement Object
        (
        )

    [shiftNumber] => 1
    [note] => SimpleXMLElement Object
        (
        )

    [payrollNumber] => SimpleXMLElement Object
        (
        )

    [lessLunchMin] => SimpleXMLElement Object
        (
        )

    [dateTimeCreated] => 2018-08-06T17:03:34
    [takenBy] => 480
    [bookedByUserId] => 480
    [orderTypeId] => 1
    [orderType] => SimpleXMLElement Object
        (
        )

    [city] => Media
    [state] => xx
    [zipCode] => xxxxx
    [orderSourceID] => SimpleXMLElement Object
        (
        )

    [orderSourceName] => SimpleXMLElement Object
        (
        )

    [lt_orderID] => 0
    [dateTimeModified] => 2018-08-06T17:03:34
    [subjectID] => SimpleXMLElement Object
        (
        )

    [subject] => SimpleXMLElement Object
        (
        )

)```


...