Jump to content
Desenvolvedores

Duvida na hora de ler XML

Recommended Posts

Bom dia eu gostaria de saber se alguém pode me ajudar, eu trabalho em uma escola de informática e estou desenvolvendo nosso site mas meus patrões resolveram fazer uma alteração no site que me deixou muito atrapalhado, temos uma lista com todos os alunos da escola e todos os alunos teriam um acesso com sua matricula para ver histórico, faltas, etc.. Mas pra isso deveria ser cadastrado aluno por aluno, posteriormente todos os dias lançar faltas daquele respectivo dia, mas para "agilizar" o trabalho resolveram que seria mais fácil se eu importasse esses dados de alguma forma para o site, bom para minha sorte eu achei no sistema que gerencia nossos alunos como gerar um relatório em xml, mas esse XML vai além da compreensão do nobre programador que aqui os fala! bom, andei dando uma pesquisada na interwebs mas nada encontrei de como posso ler um XML assim!:

[...]

<Details Level="2">
        <Section SectionNumber="0">
            <Field Name="bairro1" FieldName="{aluno1.bairro}"><FormattedValue>Centro</FormattedValue><Value>Centro</Value></Field>
            <Field Name="cep1" FieldName="{aluno1.cep}"><FormattedValue>11600000</FormattedValue><Value>11600000</Value></Field>
            <Field Name="dtnascimento1" FieldName="{aluno1.dtnascimento}"><FormattedValue>18/01/2016</FormattedValue><Value>2016-01-18</Value></Field>
            <Field Name="rg1" FieldName="{aluno1.rg}"><FormattedValue></FormattedValue><Value></Value></Field>
            <Field Name="cpf1" FieldName="{aluno1.cpf}"><FormattedValue>55555555555</FormattedValue><Value>55555555555</Value></Field>
            <Field Name="codaluno1" FieldName="{aluno1.codaluno}"><FormattedValue>1</FormattedValue><Value>1</Value></Field>
            <Field Name="codcontrato1" FieldName="{contrato1.codcontrato}"><FormattedValue>1</FormattedValue><Value>1</Value></Field>
            <Field Name="nome1" FieldName="{aluno1.nome}"><FormattedValue>Leandro Aparecido Fabricio</FormattedValue><Value>Leandro Aparecido Fabricio</Value></Field>
            <Field Name="responsavel1" FieldName="{aluno1.responsavel}"><FormattedValue>Leandro Fabricio</FormattedValue><Value>Leandro Fabricio</Value></Field>
            <Field Name="TrataFone1" FieldName="{@TrataFone}"><FormattedValue>(12) 3893-1555</FormattedValue><Value>(12) 3893-1555</Value></Field>
            <Field Name="TrataFone21" FieldName="{@TrataFone2}"><FormattedValue>(  )      -</FormattedValue><Value>(  )      -</Value></Field>
            <Field Name="EnderecoComNumero1" FieldName="{@EnderecoComNumero}"><FormattedValue>São Geraldo,29</FormattedValue><Value>São Geraldo, 29</Value></Field>
            <Field Name="CidadeUf1" FieldName="{@CidadeUf}"><FormattedValue>São Sebastião - SP</FormattedValue><Value>São Sebastião - SP</Value></Field>
        </Section>
    </Details>

[...]

Viram! até hoje só tinha visto estruturas XML simples:

<tag>
  <outratag>bla bla bla</outratag>
  <maisumatag>fulano</maisumatag>
</tag>

Mas o XML que o sistema gera possui atributos e Values, FormattedValue e vei, não entendi nada ja tentei varias formas de recuperar isso no php e nada, já tentei até limpar esse XML mas perdi 30 minutos e vi que passava de uma parte pra baixo o código estava ficando atrapalhado, e não da pra fazer registro por registro esse XML possui mais de 15 mil linhas... isso é uma importação que será feita todo dia pelo estagiário ainda se ele tiver que limpar o XML para importar F*****, o coitado vai perder muito tempo!

 

Desde já obrigado.

Share this post


Link to post
Share on other sites

No PHP existem algumas bibliotecas que você pode utilizar para manipular o XML: http://php.net/manual/en/refs.xml.php

 

As mais utilizadas são DOMSimpleXML e XMLParser. Sendo a SimpleXML mais limitada e as outras com mais recursos (XMLParser gerencia melhor a memória, mas não quer dizer que irá utilizar menos memória).

 

Cada um com seus prós e contras, você deve escolher a que mais lhe você agradar.

 

Por exemplo, se for utilizar DOM, você pode carregar o arquivo através do método DOMDocument::loadXML(). Uma vez carregado, você receberá um objeto do tipo DOMDocument, que, por sua vez, é uma especialização do objeto DOMNode.

 

DOMNode possui o atributo DOMNode::childNodes, que contém todos os nodes abaixo dele:

foreach ($domDocument->childNodes as $childNode) { 
    //Iteração sobre a lista de filhos
}

Cada node também possui o atributo DOMNode::attributes, que pode ser usado para iterar sobre os atributos do nó. Cada atributo é um objeto do tipo DOMAttr

foreach($childNode->attributes as $attr)
{
    print $attr->name.' = '.$attr->value;
}

E o valor interno de um node pode ser recuperado através do atributo DOMNode::nodeValue.

 

Nas outras bibliotecas, a teoria é praticamente a mesma, apenas mudará o nome dos atributos/funções/objetos.

  • Obrigado! 1

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 violin101
      Caros amigos, saudações...
       
      Estou usando Codeigniter e estou com uma pequena dúvida.
       
      Tenho um Form com os seguintes campos:
      Data Início..... <input type="date" /> Hora Início.... <input type="time" /> Data Final..... <input type="date" /> Hora Final.... <input type="time" /> até aqui tudo bem
       
      Gostaria de fazer uma VERIFICAÇÃO para impedir que o usuário GRAVE no MySql uma data menor que a data atual.
      ou seja:
      Data Início nunca poderá ser menor que a Data Atual.
      e a
      Data Final só poder ser igual ou maior que a Data Início.
       
      Grato,
       
      Cesar
       
    • By Salvatore
      Galerinha Boa, alguém pode me explicar como eu faço pra editar isso abaixo usando php
       
       
       <div class="nome-vip">
              <p class="text-center"><span>1</span> CASH</p>             <---------------essa parte eu queria saber como eu edito clicando por cima(tentei usando contenteditable), mas n deu do jeito que eu queria,preciso que o valor editado fique em uma variavel PHP
            </div>
            <p class="text-center" style="color: #888; font-size: 15px;">por apenas</p>
            <div class="preco-vip">
              <p class="text-center">R$ 1</p> <------------------- e aqui iria ter a variável preço que ja estaria definida como um, e quando la em cima fosse adicionado um valor int, somasse os 2 e gerasse a variavel valor e exibindo ela
            </div>
       
      Alguém ajuda eu, to caçando em mts sites algo assim mas n consigo
       
    • By drx
      Olá pessoal!
      Estou com um probleminha aqui. Estou me embrenhando pelos ajax e jquery. Muito interessante. 
      Eu peguei um exemplo e é bem simples. Só que não retorna a mensagem para a div.
       
      Eu tenho uma div em pagina1.php onde o usuário entra com um número identificador em um campo textfield.
      Após entrar com o número identificador, solicito a verificação em uma outra página.php onde tenho uma consulta no mysql.
      O echo da consulta é: Existente ou Inexistente. A consulta é feita pelo número identificador. Fiz a verificação e retorna perfeitamente,
      Porém eu quero que ao verificar, a mensagem retorne para minha outra div logo abaixo na pagina1.php
      Vou passar o código para facilitar....
       
      <html>
      <head>
       
      <script src="js/jquery.js"></script>
      <script>
      $(function(){
        $('#form').submit(function(){
           $.ajax({
             url: 'x_consultar_patro.php',
             type: 'POST',
             data: $('#form').serialize(),
             success:function ( data ) {
                 if (data != '') {
                     $('#frm_cadastro').html( data );
                 }
               }
             });
           return false;
         });
      });
      </script>
       
      </head>
       
      <body>

      <div id="frm_cadastro"></div>

      <form id="form" method="post" action="">
        <input type="text" name="codpatro" id="codpatro"/>
        <input type="submit" name="btn_procurar" id="btn_procurar" value="Procurar"/>
      </form>
       
      </body>
      <html>
       
       

    • By Claudia França
      prezados como eu altero de loked para unloked do arro para não carregar o java e seguir com o procedimento. 
       
       
      ?Veja nesse link https://drive.google.com/drive/u/0/folders/1h0EbUoz3UOL8j9orWirUAPILt7cg7q-p 
      minhas imagens não estao subindindo aqui, não sei porque, acho que tenho limitação. 
       
       
    • By Claudia França
      prezados qdo removo o require colocado antes do doctype o botão desaparece como na imagem . Alguem pode me explicar porque??    dentro do setting tem apenas informações key do cliente e configurações da conta de email. 
       


×

Important Information

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