Jump to content
ILR master

Importar campo data de um arquivo xml

Recommended Posts

Fala pessoal.

 

Estou importando um arquivo xml para o meu DB porém, não consigo ler o campo data do xml. Todos os campos são lidos, menos o campo data. No xml ele está nesse formato: 09/06/2021 23:59:00

Abaixo segue o código que estou usando:

 

$xml = simplexml_load_file('cupons.xml');

foreach($xml->coupon as $cupom) {

    echo $cupom->code.'<br>';
    echo $cupom->data.'<br>';
}

 

Obrigado!

Share this post


Link to post
Share on other sites

Olá @ILR master, tudo certo?

 

Então, você tem certeza de que data faz parte do mesmo nível hierárquico que code?

Tente visualizar os detalhes do que está sendo processado na iteração utilizando print_r ou var_dump, dentro do foreach. Assim:

$xml = simplexml_load_file('cupons.xml');

echo '<pre>';//exibir espaços em branco e formatar o print_r
foreach($xml->coupon as $cupom) {
    var_dump( $cupom );
    echo $cupom->code.'<br>';
    echo $cupom->data.'<br>';
}

// ou quem sabe: var_dump( $xml ); (fora do foreach)

Você pode dar uma olhada nos parâmetros opcionais da simplexml_load_file para ver se alguma mudança auxilia na interpretação correta do seu arquivo, caso seja esse o problema: https://www.php.net/manual/en/libxml.constants.php

 

E não esqueça de habilitar as mensagens de erro.

// no início do seu arquivo
ini_set( 'display_errors', 1 );
ini_set( 'display_startup_errors', 1 );
error_reporting( E_ALL );

 

Share this post


Link to post
Share on other sites
13 horas atrás, Matheus Tavares disse:

Olá @ILR master, tudo certo?

 

Então, você tem certeza de que data faz parte do mesmo nível hierárquico que code?

Tente visualizar os detalhes do que está sendo processado na iteração utilizando print_r ou var_dump, dentro do foreach. Assim:


$xml = simplexml_load_file('cupons.xml');

echo '<pre>';//exibir espaços em branco e formatar o print_r
foreach($xml->coupon as $cupom) {
    var_dump( $cupom );
    echo $cupom->code.'<br>';
    echo $cupom->data.'<br>';
}

// ou quem sabe: var_dump( $xml ); (fora do foreach)

Você pode dar uma olhada nos parâmetros opcionais da simplexml_load_file para ver se alguma mudança auxilia na interpretação correta do seu arquivo, caso seja esse o problema: https://www.php.net/manual/en/libxml.constants.php

 

E não esqueça de habilitar as mensagens de erro.


// no início do seu arquivo
ini_set( 'display_errors', 1 );
ini_set( 'display_startup_errors', 1 );
error_reporting( E_ALL );

 

 

Share this post


Link to post
Share on other sites

Olá @Matheus Tavares, obrigado por sua resposta.

 

Eu dei o var_dump e ele me trás a seguinte estrutura:

Onde era data, alterei pra endDate.

 

object(SimpleXMLElement)[5]
  public 'code'    (length=16)
  public 'vigency'  
    object(SimpleXMLElement)[6]
      public 'endDate'    (length=19)
  public 'link'    (length=40)
  public 'discount'    (length=2)
  public 'store'  
    object(SimpleXMLElement)[7]
      public 'name'    (length=6)
      public 'id'    (length=4)
      public 'image1'    (length=58)
  public 'title'    (length=76)
  public 'category'  
    object(SimpleXMLElement)[8]
      public 'name'    (length=18)
      public 'id'    (length=2)

 

 

Obrigado.

Share this post


Link to post
Share on other sites

@Matheus Tavares, bom dia.
Já consegui aqui rs....

 

$xml = simplexml_load_file('cupons.xml');

echo '<pre>';//exibir espaços em branco e formatar o print_r
foreach($xml->coupon as $cupon) {
    //var_dump( $cupon );
    echo $cupom = $cupon->code.'<br>';
    echo $validade = $cupon->vigency->endDate.'<br>';
    echo $url = $cupon->link.'<br>';
    echo $desconto = $cupon->discount.'<br>';
    echo $loja = $cupon->store->name.'<br>';
    echo $id = $cupon->store->id.'<br>';
    echo $foto = $cupon->store->image1.'<br>';
    echo $titulo = $cupon->title.'<br>';
    echo $categoria = $cupon->category->name2;
}

 

Mas muito obrigado por sua ajuda. Abs

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Caio Vargas
      Fala pessoal tudo bem
      Estou criando um site para o cliente e ele me pediu para colocar um tradutor ao clicar nas bandeiras
      porem eu nao queria fazer uma pagina para cada traduçao eu queria fazer tipo usando o google Translate 
       
      alguem tem alguma sugetao de como posso fazer ou um exemplo 
      grato
    • By Kelven
      Bom dia pessoal tudo bem?
      Então, estou trabalhando em um site em php e preciso usar a api do facebook para obter o feed do instagram, porém a chave token é um conteúdo muito sensível, então decidi fazer em php para ela não ficar disponível do lado do cliente. Alguém sabe me dizer se é possível fazer isso? Porque eu pesquisando no google só achei maneiras de fazer em javascript.
    • By gersonab
      Boa noite, tenho pesquisado porém não encontrei, então vamos lá.
      tenho uma lista de itens ( documentos ) cadastrados no banco de dados e os seus respectivos arquivos em uma pasta, se eu preciso de um deles clico e faço o download deste, no entanto como fazer para fazer o download de vários ao selecionar com checkbox os que eu quero ?
      desculpem por não postar nenhum código, mas é que não estou sabendo como fazer os downloads de vários.
      Qual o procedimento correto ?
       
    • By Willian Simione
      Estou com duas tabelas onde  uma eu somo o km de cada carro, e outra que eu somo a quantidade de litragem abastcido, porem tem carro que não abastece na garagem e na hora d eeu mostrar  a media por carro abastecido ele acaba entrando no somatório e é onde da o erro Warning: Division by zero in, como faço pra fazer essa soma e excluir os carro que não estao com o abastecimento.Abaido deixo as tabelas
       
      Esse soma o KM , todos os carro tem KM
       $soma4 = $conectar->query("SELECT SUM(tkm) AS total FROM cad_km where carro='$carro'");
         $count4 = $soma4->fetchColumn();
      Esse soma a Litragem, porem o tem carro que não abastece, 
         $soma3 = $conectar->query("SELECT round(SUM(litros),0) AS total FROM cad_abastec where dtabastec BETWEEN '$data1' AND '$data2' and carro='$carro'");
         $count3 = $soma3->fetchColumn();
       

       
    • By Mauricio Molina
      Bom dia.
       
      Estou precisando de um freelancer em PHP.
       
      Resolver um problema em um script de portal de noticias, onde a imagem não esta sendo upada, fica apenas em "em processamento".
       
      Contato: contato@weblina.com.br
       
      Obrigado!

×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.