Ir para conteúdo

POWERED BY:

Arquivado

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

free4k

Trabalhar com datas no XML

Recommended Posts

Olá, tudo bem pessoal? Preciso ler datas de registros no XML e calcular quantos registros que há na semana atual. Com MySQL consigo fazer, porém com XML não tenho ideia de como fazer. Podem me ajudar? Obrigado.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Detalhada, já com a data.

<playlist>
<item>
<filename>cd1</filename>
<endip>meu ip</endip>
<data>06/10/2015</data>
</item>
<item>
<filename>cd2</filename>
<endip>meu ip</endip>
<data>06/10/2015</data>
</item>
<item>
<filename>cd3</filename>
<endip>meu ip</endip>
<data>06/10/2015</data>
</item>
</playlist>

Compartilhar este post


Link para o post
Compartilhar em outros sites

Apareceu um erro:

(!) Capturável erro fatal: Argumento 1 passado para DOMXPath :: __ construct () deve ser uma instância de DOMDocument, string dada em [...] (na linha $XP = new...)

$XML = "downloads.xml";
$Data = date(date("d/m/Y"));

$XP = new DOMXPath($XML);
$Query = $XP->query('//data[contains(., $Data)]');

foreach($Query as $Valor):
    var_dump($Valor->nodeValue);
endforeach;

Fiz algo errado?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Sim, o xml tem que ser em string não em arquivo, usa file_get_contents

 

Fiz isso, porém apareceu o mesmo erro.

$XML = file_get_contents("downloads.xml");
$Data = date(date("d/m/Y"));

$XP = new DOMXPath($XML);
$Query = $XP->query('//data[contains(., $Data)]');

foreach($Query as $Valor):
    var_dump($Valor->nodeValue);
endforeach;

Obrigado.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Pronto :) :

$XML = file_get_contents('download.xml'); // Obtem o conteudo do download.xml.
$XML = new SimpleXMLElement($XML); // Inicia o SimplesXMLElement, informando o nosso download.xml como parâmetro para a __construct.
$Query = $XML->xpath('/playlist//item'); // XPath query, obtendo todos os item.

$Itens = json_decode(json_encode($Query), true); // Transformando os objetos em arrays, se tiver um método melhor use !

$Data = date("d/m/Y"); // Obtendo a data atual, adicione um item ao seu XML para teste.
$Item = false; // Mais pra frente usaremos para armazenar o array com os dados encontrados, logo, tornei false de começo.

foreach($Itens as $Key => $Value):
	if(in_array($Data, $Value)): // Verifica se no array percorrido existe o valor que desejamos, a data.
		$Item = $Value; // Encontrou o valor, seta para a $Item, ele não será mais false, de agora em diante será um array.
		break; // Não precisamos mais percorrer este array pois o valor já foi encontrado, pare foreach !
	endif;
endforeach;

// Temos o array pronto, você pode usar o var_dump($Item); para verificar se está tudo certo, vamos então exibir estes itens:
echo "Filename: " . $Item['filename'] . "</br>";
echo "EndIP: " . $Item['endip'] . "</br>";
echo "Data: " . $Item['data'] . "</br>";

Exemplo com cURL (Recomendo usar cURL):

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'download.xml');
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$XML = curl_exec($ch);
curl_close($ch);

$XML = file_get_contents('download.xml'); // Obtem o conteudo do download.xml.
$XML = new SimpleXMLElement($XML); // Inicia o SimplesXMLElement, informando o nosso download.xml como parâmetro para a __construct.
$Query = $XML->xpath('/playlist//item'); // XPath query, obtendo todos os item.

$Itens = json_decode(json_encode($Query), true); // Transformando os objetos em arrays, se tiver um método melhor use !

$Data = date("d/m/Y"); // Obtendo a data atual, adicione um item ao seu XML para teste.
$Item = false; // Mais pra frente usaremos para armazenar o array com os dados encontrados, logo, tornei false de começo.

foreach($Itens as $Key => $Value):
	if(in_array($Data, $Value)): // Verifica se no array percorrido existe o valor que desejamos, a data.
		$Item = $Value; // Encontrou o valor, seta para a $Item, ele não será mais false, de agora em diante será um array.
		break; // Não precisamos mais percorrer este array pois o valor já foi encontrado, pare foreach !
	endif;
endforeach;

// Temos o array pronto, você pode usar o var_dump($Item); para verificar se está tudo certo, vamos então exibir estes itens:
echo "Filename: " . $Item['filename'] . "</br>";
echo "EndIP: " . $Item['endip'] . "</br>";
echo "Data: " . $Item['data'] . "</br>";

Compartilhar este post


Link para o post
Compartilhar em outros sites

Apareceu erro na linha "$XML = new SimpleXMLElement($XML);".

 

 

 

( ! ) Fatal error: Uncaught exception 'Exception' with message 'String could not be parsed as XML' in C:\wamp\www\leo\index.php on line 50 ( ! ) Exception: String could not be parsed as XML in C:\wamp\www\leo\index.php on line 50

Compartilhar este post


Link para o post
Compartilhar em outros sites

Try ae my friend:

$XML = file_get_contents('download.xml'); //Obtem o conteudo do download.xml.
$XML = new SimpleXMLElement($XML); //Inicia o SimplesXMLElement, informando o nosso download.xml como parâmetro para a __construct.
$Query = $XML->xpath('/playlist//item'); //XPath query, obtendo todos os item.

$Itens = json_decode(json_encode($Query), true); //Transformando os objetos em arrays, se tiver um método melhor use !

$SemanaAtual = date('W', strtotime(date("Y-m-d"))); //Obtendo a semana atual.

$CDS = []; //Mais pra frente usaremos para armazenar o array com os dados encontrados, por enquanto ela é um array vazio, do tipo false

foreach($Itens as $Key => $Value):
	if(date('W', strtotime(str_replace('/', '-', $Value['data']))) == $SemanaAtual):
		$CDS[] = $Value; //Encontrou o valor, seta para a $CDS, ele não será mais false, de agora em diante será um array.
	endif;
endforeach;

if($CDS):
	foreach($CDS as $CD):
		echo "Filename: " . $CD['filename'] . "</br>";
		echo "EndIP: " . $CD['endip'] . "</br>";
		echo "Data: " . $CD['data'] . "</br>";
	endforeach;
else:
	echo "Nenhum registro encontrado para a semana atual !";
endif;

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por daemon
      Boa tarde,
       
      Duvida simples...
       
      Quando recupero os dados RSS, para inserir no banco de dados esta salvando corretamento porém no mysql esta com (ponto) . na frente de todos os registros via RSS.
       
      Fica com um ponto na frente outro atras...
       
      Data/hora:
      .2024-11-30 10:03:47.
    • Por ILR master
      Fala galera.
      Espero que todos estejam bem.
      Seguinte: Tenho um arquivo xml onde alguns campos estão com : (dois pontos), como o exemplo abaixo:
       
      <item>
      <title>
      d sa dsad sad sadasdas
      </title>
      <link>
      dsadas dsa sad asd as dsada
      </link>
      <pubDate>sadasdasdsa as</pubDate>
      <dc:creator>
      d sad sad sa ad as das
      </dc:creator>
      </item>
       
      Meu código:
       
      $link = "noticias.xml"; 
      $xml = simplexml_load_file($link); 
      foreach($xml -> channel as $ite) {     
           $titulo = $ite -> item->title;
           $urltitulo = $ite -> item->link;
           print $urltitulo = $ite -> item->dc:creator;
      } //fim do foreach
      ?>
       
      Esse campo dc:creator eu não consigo ler. Como faço?
       
      Agradeço quem puder me ajudar.
       
      Abs
       
       
    • Por Jack Oliveira
      Boa noite galera..
       
      Estou tentando gerar um sitemap com php
       
      So que tenho que por o limit 1200 
       
      mais que isso ele nao gera e se deixar sem limit 
       
      Obs: o banco de dados contem mais de 10 mil registros
      <?php // Data e hora atual $datetime = new DateTime(date('Y-m-d H:i:s')); // A linha abaixo me retornará uma data no seguinte formato: 2017-11-22T00:06:23-02:00 $date = $datetime->format(DateTime::ATOM); // ISO8601 // Gera o arquivo XML do sitemap $xml = '<?xml version="1.0" encoding="UTF-8"?> <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.sitemaps.org/schemas/sitemap/0.9/sitemap.xsd"> <url> <loc>'.ConfigPainel('site_url').'</loc> <lastmod>'.$date.'</lastmod> <changefreq>weekly</changefreq> <priority>1.00</priority> </url>'; $Query = DBRead('cidades','*',"WHERE status ='1' ORDER BY nome ASC"); if (is_array($Query)) { foreach ($Query as $modcid) { $xml .=' <url> <loc>'.ConfigPainel('site_url').''.$modcid['subdominio'].'/</loc> <lastmod>'.$date.'</lastmod> <changefreq>weekly</changefreq> <priority>1.00</priority> </url>'; //$QueryR = DBRead('directory_guia', '*',"WHERE cidade='{$modcid['id']}' AND status='1' ORDER BY titulo ASC"); $QueryR = DBRead('directory_guia', '*',"WHERE cidade='{$modcid['id']}' AND status='1' ORDER BY titulo ASC LIMIT 1200"); if (is_array($QueryR)) { foreach ($QueryR as $v) { $Queryc = DBRead('cidades', '*',"WHERE id='{$v['cidade']}' ORDER BY nome ASC")[0]; if(empty($v['slug'])) { }else{ $urlseo = ''.ConfigPainel('site_url').''.$Queryc['subdominio'].'/list/'.$v['slug'].'/'; $xml .=' <!-- INICIO DA EMPRESA '.TRIM($v['titulo']).' --> <url> <loc>'.$urlseo.'</loc> <lastmod>'.$date.'</lastmod> <changefreq>weekly</changefreq> <priority>0.85</priority> </url> <!-- FIM DA EMPRESA '.TRIM($v['titulo']).' --> '; } }} }} $xml .= ' </urlset>'; // Abre o arquivo ou tenta cria-lo se ele não exixtir $arquivo = fopen('../sitemap.xml', 'w'); if (fwrite($arquivo, $xml)) { Redireciona('./index.php?sucesso'); } else { Redireciona('?erro'); } fclose($arquivo); // Compactar arquivo sitemap para GZIP $data = implode("", file("sitemap.xml")); $gzdata = gzencode($data, 9); $fp = fopen("sitemap.xml.gz", "w"); fwrite($fp, $gzdata); fclose($fp); // Envia para o Google o novo sitemap gerado $urlSitemap = "http://www.google.com/webmasters/sitemaps/ping?sitemap=".ConfigPainel('site_url').""; // Arquivos a serem enviados $Files = ['sitemap.xml', 'sitemap.xml.gz']; // Envia os dois arquivos sitemap gerados para a URL do Google foreach ($Files as $file) { $url = $urlSitemap . $file; $ch = curl_init($url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_exec($ch); $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE); curl_close($ch); } ?> Caso ouve outra forma que eu possa gerar este sitemap com php fico grato...
    • Por marcelo.ourico
      Estou precisando fazer o envio de um XML via webservice. Estou utilizando PHP 7.4 e nuSoap.

      Porém esse XML de envio possui várias tags com hífen. Por exemplo <tag-name></tag-name>.
       
      Esse hífen tem sido um problema, principalmente por que eu não posso enviar o XML como string. Apenas como objeto. Então imaginem isso:
       
      $objeto = simplexml_load_string($string_xml);  
      Se simplesmente eu tentar resgatar o valor da TAG já dá erro...
       
      $campo1= $objeto->tag-name;
      O erro ocorre em função de que o hífen é um caractere reservado do PHP... Então como resolver?

      Independente disso, quando eu tento fazer o envio via nuSoap, também recebo erro abaixo:
      wsdl->getTypeDef('tag-name', 'http://xyz.abr...')
      wsdl->serializeType('tag-name', 'tag-name', Object(SimpleXMLElement), '

      Alguém já passou por isso? Sabe como resolver? Pode dar uma dica?
    • Por alessandra.barreto
      Boa Tarde
      Estou fazendo uma importacao de dados do SQL pro Oracle.
      Tenho campos (datetime2(7)) no SQL e Date no Oracle.
      Não consigo fazer a importação, o Oracle retorna erro de  [Microsoft][ODBC Oracle Wire Protocol driver]Timestamp parameters with a scale, must have a scale less than ten and a precision equal to 20 plus the scale.  You specified a precision of 0 and scale of 6. ". Alguém pode me ajudar?

       
×

Informação importante

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