让我们看一些代码来更好地解释: 我向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”项。我该怎么办?
答案 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”,这是我正在寻找的值。我认为这解决了问题!谢谢,伙计,你是男人!