Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

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

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

  • Conteúdo Similar

    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
    • Por First
      Olá a todos!
       
      Quando eu tento fazer o login me mostra esse erro "Could not log you in."; Alguém sabe me ajudar a resolver esse problema no meu código?
      <?php require_once("core/init.php"); if (Input::exists()) { if (Token::check(Input::get("token"))) { $validate = new Validate(); $validation = $validate->check($_POST, array( "username" => array("required" => true), "password" => array("required" => true) )); if ($validation->passed()) { $user = new User(); $remember = (Input::get("remember")) === "on" ? true : false; $login = $user->login(Input::get("username"), Input::get("password"), $remember); if ($login) { Session::flash("home", "Welcome back!"); Redirect::to("index.php"); } else { echo "Could not log you in."; } } else { foreach ($validation->errors() as $error) { echo $error."<BR>"; } } } } ?> <form action="" method="POST"> <div class="field"> <label for="username">Username</label> <input type="text" name="username" id="username"> </div> <div class="field"> <label for="password">Password</label> <input type="password" name="password" id="password"> </div> <div class="field"> <label for="remember"> <input type="checkbox" name="remember" id="remember"> Remember me </label> </div> <input type="hidden" name="token" value="<?php echo Token::generate(); ?>"> <input type="submit" value="Log in"> </form>  
       
      Desde já obrigado.
    • Por ckcesar
      Eu tenho uma aplicação no zend com a versão 5.6 e com o postgresql 9.6. Agora eu precisei mudar a versão do meu postgresql para o 16.1, a parte de conexão do bd e consultas sqls funciona perfeitamente, o meu problema está para acessar os meus controllers. Eles não são encontrados em nenhuma rota, quero ver se alguém já passou por esse problema para me ajudar. Obrigado.
    • Por ILR master
      Fala galera, tudo bem?
       
      Tenho o seguinte codigo:
       
       class Data {
      public static function ExibirTempoDecorrido($date)
      {
          if(empty($date))
          {
              return "Informe a data";
          }
          $periodos = array("segundo", "minuto", "hora", "dia", "semana", "mês", "ano", "década");
          $duracao = array("60","60","24","7","4.35","12","10");
          $agora = time();
          $unix_data = strtotime($date);
          // check validity of date
          if(empty($unix_data))
          {  
              return "Bad date";
          }
          // is it future date or past date
          if($agora > $unix_data) 
          {  
              $diferenca     = $agora - $unix_data;
              $tempo         = "atrás";
          } 
          else 
          {
              $diferenca     = $unix_data - $agora;
              $tempo         = "agora";
          }
          for($j = 0; $diferenca >= $duracao[$j] && $j < count($duracao)-1; $j++) 
          {
              $diferenca /= $duracao[$j];
          }
          $diferenca = round($diferenca);
          if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
          return "$diferenca $periodos[$j] {$tempo}";
      }
      }
       
      Funciona redondinho se o valor retornado for de algumas horas, mas...
      Quando passa de dois meses, ele retorna a palavra mess. Deve ser por conta dessa linha
      if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
       
      Quero que modre:
       
      2 meses atrás
      e não
      2 mess atrás.
       
      Espero que tenham entendido.
       
      Valeu
×

Informação importante

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