我该如何处理?

时间:2019-07-04 18:51:41

标签: php arrays json laravel

让我们看一些代码来更好地解释: 我向WS发出了如下波纹请求:

        $idERP = 1;
        $grupoEcota = new \SoapClient($url);
        $paramExtrato = array(
            'sGrupo' => $request->sGrupo,
            'iCota' => $request->iCota,
            'iIdERP' => $idERP,
        );
        $responseExtrato = $grupoEcota->ROS_ExtratoContaCorrente($paramExtrato);
        $grupoEcota = $responseExtrato->ExtratoContaCorrente;

我从WS(巫婆和转储)那里得到了一个WS女巫的回复:


$dados[] = $grupoEcota->{'PARCELAS-PAGAS'};
        dd($dados);

array:1 [▼
  0 => {#784 ▼
    +"PARCELA-PAGA": array:21 [▼
      0 => {#783 ▼
        +"NUMERO-PARCELA": 48
        +"DATA-VENCIMENTO": "20170818"
        +"DATA-PAGAMENTO": "20170919"
        +"VALOR-PARCELA": 580.28
        +"HITORICO-PARCELA": ""
        +"PERC-PAGO": 3.491
      }
      1 => {#771 ▶}
      2 => {#781 ▶}
      3 => {#780 ▶}
      4 => {#779 ▶}
      5 => {#778 ▶}
      6 => {#777 ▶}
      7 => {#776 ▶}
      8 => {#775 ▶}
      9 => {#774 ▶}
      10 => {#773 ▶}
      11 => {#772 ▶}
      12 => {#757 ▶}
      13 => {#770 ▶}
      14 => {#769 ▶}
      15 => {#768 ▶}
      16 => {#767 ▶}
      17 => {#766 ▶}
      18 => {#765 ▶}
      19 => {#764 ▶}
      20 => {#763 ▶}
    ]
  }
]

我只需要获取第一个“ DATA-VENCIMENTO”:“ 20170818”项。我该怎么办?

2 个答案:

答案 0 :(得分:0)

首先,您要处理数组,让我们取出第一个元素(我的假设是只有一个元素。)

$data= $data[0];

现在我们有了一个键值数组,我们现在可以提取PARCELA-PAGA

$parcels = $data{'PARCELA-PAGA'];

数组中的多个对象是下一个级别,这意味着每个对象中都有数据,因此我将使用array_pluck将这些元素取出。

$vencimento = array_pluck($parcels, 'DATA-VENCIMENTO');

如果您不关心多个数据字段,则只需采用第一个元素。请注意,这些数据不是数组,而是对象。

$vencimento = $parcels[0]->DATA-VENCIMENTO;

哪个结果应该像这样

[""20170919"", "20171019", ...]

答案 1 :(得分:0)

得到朋友的帮助:

$firstRecord = collect($dados[0]->{'PARCELA-PAGA'})->firstWhere('DATA-VENCIMENTO', '20170818');

dd($firstRecord);

然后...

{#783 ▼
  +"NUMERO-PARCELA": 48
  +"DATA-VENCIMENTO": "20170818"
  +"DATA-PAGAMENTO": "20170919"
  +"VALOR-PARCELA": 580.28
  +"HITORICO-PARCELA": ""
  +"PERC-PAGO": 3.491
}

我完成了:

dd($firstRecord->{'DATA-VENCIMENTO'});

我得到了“ 20170818”,这是我正在寻找的值。我认为这解决了问题!谢谢,伙计,你是男人!