Ir para conteúdo
markhosbh

Atribuir conteúdo Json à variável PHP (RESOLVIDO)

Recommended Posts

Salve galera,
Estou iniciando no mundo WebService e já me deparo com o seguinte problema.

O Servidor da TOTVS via rest, me retorna exatamente da seguinte forma:

   

$resposta = enviaConteudoParaAPI($cabecalho, $conteudo, $url, $tpRequisicao);
    print_r($resposta);

Resultado:

    {"CAMPOS":"[\"\"A1_COD\",\"A1_NOME\",\"TIPO\"]","DADOS":"[[\"00932221\",\"PEDRO GONCALVES\",\"TITULAR\"][\"00164577\",\"JORGE ARAGAO\",\"TITULAR\"]]"}


    
    //TRATADO
   

$array = json_decode($resposta, true);
        $campos = $array['CAMPOS'];
        $dados = $array['DADOS'];
        print_r($array);

Resultado :

   

Array ( [CAMPOS] => [""A1_COD","A1_NOME","TIPO"] [DADOS] => [["00932221","PEDRO GONCALVES","TITULAR"]["00164577","JORGE ARAGAO","TITULAR"]] ) 


Acontece que preciso atribuir cada conteúdo a uma variável, ou seja, preciso trabalhar com cada valor de forma distinta:

       

$A1_COD = ['$A1_COD'];
        $A1_NOME = ['A1_NOME'];
        $TIPO = ['TIPO'];
    echo "Codigo: $A1_COD, Nome: $A1_NOME, Tipo: $TIPO";

Onde eu preciso do seguinte resultado:

    Codigo: 00932221 , Nome: PEDRO GONCALVES, Tipo: TITULAR
    Codigo: 00164577 , Nome: JORGE ARAGAO,       Tipo: TITULAR  

 
Em outras palavras, preciso transformar este array:

   

  Array ([["00932221","PEDRO GONÇALVES","TITULAR"]["00164577","JORGE ARAGAO","TITULAR"]])

Neste array:

    Array ( [A1_COD] => 00932221 [A1_NOME] => PEDRO GONÇALVES [TIPO] => TITULAR ) 
    Array ( [A1_COD] => 00164577 [A1_NOME] => JORGE ARAGAO [TIPO] => TITULAR )


 

Compartilhar este post


Link para o post
Compartilhar em outros sites
45 minutos atrás, markhosbh disse:

Acontece que preciso atribuir cada conteúdo a uma variável, ou seja, preciso trabalhar com cada valor de forma distinta:

 


Precisa mesmo, isso não atenderia?

foreach($dados as $valor) {
    $valor[0] é o código
    $valor[1] é o nome
    $valor[2] é o tipo
}


Mas respondendo a pergunta:

 

49 minutos atrás, markhosbh disse:

Em outras palavras, preciso transformar este array:

   


  Array ([["00932221","PEDRO GONÇALVES","TITULAR"]["00164577","JORGE ARAGAO","TITULAR"]])

Neste array:


    Array ( [A1_COD] => 00932221 [A1_NOME] => PEDRO GONÇALVES [TIPO] => TITULAR ) 
    Array ( [A1_COD] => 00164577 [A1_NOME] => JORGE ARAGAO [TIPO] => TITULAR )


Tente isso:

$novoArray = [];
array_map(function($array) use($campos, &$novoArray) {
    $novoArray[] = array_combine($campos, $array);
}, $dados);

print_r($novoArray);

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

@EdCesar ,

Precisa mesmo, isso não atenderia?

foreach($dados as $valor) {
    $valor[0] é o código
    $valor[1] é o nome
    $valor[2] é o tipo
}

Atenderia também, mas para as duas soluções apresentadas retorna um array vazio: array().

É normal vir do Json com essa estrutura apresentada? em toda pesquisa que fiz não vi nada parecido.

Sgue outro exemplo a ser tratado:

{"CAMPOS":"[\"\"A1_COD\",\"A1_NOME\",\"TIPO\"]","DADOS":"[[\"33436681\",\"MARCOS ALAN \",\"REPRESENTANTE\"][\"34007644\",\"MARCOS ALBERTO \",\"TITULAR\"][\"67762840\",\"MARCOS ALVES \",\"TITULAR\"][\"55178561\",\"MARCOS ANTONIO \",\"TITULAR\"][\"53105010\",\"MARCOS FERREIRA\",\"TITULAR\"][\"38908328\",\"MARCOS  HIPOLITO \",\"TITULAR\"]]"}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

@markhosbh, joia!

 

5 horas atrás, markhosbh disse:

É normal vir do Json com essa estrutura apresentada? em toda pesquisa que fiz não vi nada parecido.

 


A estrutura do json, depende do problema que você esta querendo resolver, o importante é que seja um json valido!

Veja só:

<?php

// Considerando que você tenha uma estrutura de json, valida!
$jsonString = '{
	"CAMPOS": ["A1_COD", "A1_NOME", "TIPO"],
	"DADOS": [
		["33436681", "MARCOS ALAN", "REPRESENTANTE"],
		["34007644", "MARCOS ALBERTO", "TITULAR"],
		["67762840", "MARCOS ALVES", "TITULAR"],
		["55178561", "MARCOS ANTONIO", "TITULAR"]
	]
}';

$array = json_decode($jsonString, true);

$novoArray = [];

foreach ($array['DADOS'] as $dados) {
    $novoArray[] = array_combine($array['CAMPOS'], $dados);	
}

echo "<pre>";
print_r($novoArray);

Array
(
    [0] => Array
        (
            [A1_COD] => 33436681
            [A1_NOME] => MARCOS ALAN
            [TIPO] => REPRESENTANTE
        )

    [1] => Array
        (
            [A1_COD] => 34007644
            [A1_NOME] => MARCOS ALBERTO
            [TIPO] => TITULAR
        )

    [2] => Array
        (
            [A1_COD] => 67762840
            [A1_NOME] => MARCOS ALVES
            [TIPO] => TITULAR
        )

    [3] => Array
        (
            [A1_COD] => 55178561
            [A1_NOME] => MARCOS ANTONIO
            [TIPO] => TITULAR
        )

)

Se esse é o resultado que você precisa, então note que editei a string do json, para ser um json valido. Sendo assim, então você só precisa se certificar de que a função enviaConteudoParaAPI esta retornando um json valido.

Você pode utilizar algum serviço, como o https://jsonlint.com/ para validar o seu json

Editado por EdCesar
Refatoração: Trocado array_map por foreach, para melhorar legibilidade

Compartilhar este post


Link para o post
Compartilhar em outros sites

@EdCesar, bom dia!

 

Cara, era isso mesmo, o retorno estava com aspas a mais por isso não consumia da forma correta.

Muito obrigado parceiro. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por RSN
      Boa Noite, 
      Gostaria de saber se existe a possibilidade de gravar além do id do option value outra variavel, para enviar via post.
      <div class="form-group"> <label class="col-md-4 control-label" for="txtgrupo">Tipo de Pagamento : </label> <div class="col-md-4"> <select id="" class="selectpicker" data-live-search="true" name="tipo_pagamento" > <?php $query = mysql_query("SELECT * FROM tipo_pagamento ORDER BY id ASC"); while($result = mysql_fetch_array($query)) { echo '<option value="'.$result["id"].'">'.$result["nome_tipo"].'</option>'; } ?> </select> </div> </div>  
    • Por JeanTDZ
      Eu tenho um form com algumas informações etc. O form envia pro banco de dados e tudo mais, funcional.
       
      Alguém teria algum exemplo que após o submit, o form é transformado em pdf/doc e direcionado para uma pasta/ftp já criada.?
    • Por jparenque
      Pessoal, estou precisando de um código em php que faça o seguinte:

      1- acesse uma url capture e grave o código fonte
      2- acesse novamente a mesma url, capture o código fonte e compare com o código da primeira captura
      3- se o código for igual ao da primeira captura ele acessa novamente e compara novamente
      4- se o código for diferente do da primeira captura ele tem que abrir o navegador Chrome e ir para essa url através do navegador.
      5- o fim do código deverá ser apenas quando ele acessar a url encontrar um conteúdo diferente do da primeira captura.

      Vou rodar o php na máquina local. O objetivo é monitorar uma página url específica com relação à uma alteração que ocorrerá. E quando ocorrer precisarei atuar nessa página imediatamente.

      Obrigado a todos!
    • Por reisleandro
      Alguém ai conhece um servidor php portável que possa rodar direto de um pendrive e que não apresente a mensagem de bloqueio do firewall (Imagem abaxio). O servidor embutido do php faz exatamente isso mas apenas como sigle thread. Queria uma solução um pouco mais robusta que pudesse rodar em qualquer maquina sem apresentar essa mensagem. Plataforma alvo Windows.
       

    • Por JOSELUISALD
      Bom dia. Em minha aplicação o cliente quer uma cópia de seu sistema localmente e remoto (hospedado). Tem como eu fazer a sincronização dos bancos de dados, para que tudo que seja feito localmente seja inserido automaticamente no banco remoto? Desde já obrigado.
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.