Ir para conteúdo

POWERED BY:

Arquivado

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

führ

ler e importar txt zipado

Recommended Posts

Olá
tenho uma aplicação de controle onde envio o arquivo txt zipado para leitura e insert no bd, acontece q não estou conseguindo inserir todos as linhas do arquivo, gravando somente uma (a primeira), não consigo ver onde estou errando.
Adaptei de uma aplicação onde importo um txt, ignorando o cabeçalho e linhas em branco se existirem, isto também não estou conseguindo no arquivo zipado,
Se puderem me ajudar, agradeço.
segue código

 

/////////////////////////////////////////
$pathFile     =  $this->Ini->path_doc . "/" . {arquivo};

$zip = zip_open($pathFile);

if ($zip)
  {
  while ($zip_entry = zip_read($zip))
    {
    echo "<p>";
    echo "Name: " . zip_entry_name($zip_entry) . "<br />";

    if (zip_entry_open($zip, $zip_entry))
      {
		$contents = zip_entry_read($zip_entry);
      echo "File Contents:<br/>";
		echo $contents;
      
		//if(strlen(trim($zip_entry)) >= 0) {
		
		$dados = explode(";", $contents, 1028);
	
		$campo1 = str_replace("'","",$dados[0]); //RETIRA O ' DA COLUNA
		$campo2 = str_replace("'","",$dados[1]);
		$campo3 = str_replace("'","",$dados[2]);
		$campo4 = str_replace("'","",$dados[3]);
		$campo5 = str_replace("'","",$dados[4]);
		$campo6 = str_replace("'","",$dados[5]);
		$campo7 = str_replace("'","",$dados[6]);
		$campo8 = str_replace("'","",$dados[7]);
		$campo9 = str_replace("'","",$dados[8]);
		$campo10 = str_replace("'","",$dados[9]);
		$campo11 = str_replace("'","",$dados[10]);
		$campo12 = str_replace("'","",$dados[11]);
		$campo13 = str_replace("'","",$dados[12]);
		$campo14 = str_replace("'","",$dados[13]);
		$campo15 = str_replace("'","",$dados[14]);
		$campo16 = str_replace("'","",$dados[15]);
		$campo17 = str_replace("'","",$dados[16]);
		$campo18 = str_replace("'","",$dados[17]);
		$campo19 = str_replace("'","",$dados[18]);
			$data = $campo9; 
$dia = substr($data, 0, 2);
$mes = substr($data, 3, 2);
$ano = substr($data, 6, 4);
$campo9_gravar = $ano."-".$mes."-".$dia;
		
	$valor_bruto = floatval(str_replace(',', '.', str_replace('.', '', $campo6)));
	$total_nfe = floatval(str_replace(',', '.', str_replace('.', '', $campo17)));
	$quantidade = floatval(str_replace(',', '.', str_replace('.', '', $campo4)));
	
	echo
	$inserir = sc_exec_sql("INSERT into anual(ncm, descricao, cfop, quantidade, unidade, valor_bruto, opracao_nfe, situacao_nfe, data_nfe, ie_emitente, uf_emitente, ie_destinatario, uf_destino, modelo_df, serie_nfe, nfe, total_nfe, situacao_aim, chave_acesso, ano, cliente_id, ncm2, data_lancamento) VALUES ('$campo1', '$campo2', '$campo3', '$quantidade', '$campo5',  '$valor_bruto',  '$campo7',  '$campo8',  '$campo9_gravar',  '$campo10',  '$campo11',  '$campo12',  '$campo13',  '$campo14',  '$campo15',  '$campo16',  '$total_nfe',  '$campo18',  '$campo19','{ano}', 
	'{cliente}','$campo1', '{data_lancamento}')"); //INSERE CADA LINHA

			} // FECHA REMOÇÃO DA LINHA EM BRANCO
		//}
		
		
      
      zip_entry_close($zip_entry);
	  }
      

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

olá novamente está exibindo na tela todos os dados do arquivo conforme  echo $contents;, apresenta na tela a mensagem de sucesso conforme codigo q implementei

if($inserir == true){
      echo"Sucesso";}
   else{
      echo"Erro";}
}


 mas no banco de dados só insere a primeira linha do arquivo
aguardo ajuda

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por Fernando Rafael
      Boa tarde, estou com um problema ao tentar usar o CMD para imprimir o conteúdo de um arquivo TXT, estou usando o comando:
       
      PRINT /d:"\\cxgeral\Brother HL-1210W series" "imprimir.txt"  
      A impressora responde e faz o processo de impressão, porém a página sai em branco, usando este mesmo comando em uma impressora de pedido (Daruma DR800, Epson T20X, Elgin i9) funciona normalmente. mas em uma impressora comum fica em branco, sei que as impressoras na qual deram certo permitem impressão escrevendo direto na porta na qual estão instaladas. Mas a minha "Brother Hl-1210W" é uma impressora laser A4.
       
      Agradeço pela atenção.
       
       
      visite: www.sisnorg.com
    • Por Gilberto Jr
      Olá, boa tarde.
      Tudo bem?
       
      Preciso de uma ajuda aqui.
       
      Seguinte, através desse código eu consigo ler as informações que esta dentro do arquivo txt.
      <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width" /> <title>FileAPI HTML5</title> <style type="text/css"> #filecontents { border: double; overflow-y: scroll; height: 400px; } </style> </head> <body> Por favor selecione arquivo que será lido:<br /> <input type="file" id="txtfiletoread" /><br /> <div>Conteúdo do arquivo:</div> <div id="filecontents"> </div> <script> window.onload = function () { //Check the support for the File API support if (window.File && window.FileReader && window.FileList && window.Blob) { var fileSelected = document.getElementById('txtfiletoread'); fileSelected.addEventListener('change', function (e) { //Set the extension for the file var fileExtension = /text.*/; //Get the file object var fileTobeRead = fileSelected.files[0]; //Check of the extension match if (fileTobeRead.type.match(fileExtension)) { //Initialize the FileReader object to read the 2file var fileReader = new FileReader(); fileReader.onload = function (e) { var pontovirgula = ";"; var virgula = ","; var fileContents = document.getElementById('filecontents'); fileContents.innerText = fileReader.result.replace(virgula, pontovirgula).replace(virgula, pontovirgula); } fileReader.readAsText(fileTobeRead); } else { alert("Por favor selecione arquivo texto"); } }, false); } else { alert("Arquivo(s) não suportado(s)"); } } </script> </body> </html> So que o arquivo vem separado por virgulas. Eu quero substituir todas as virgulas por ponto e virgula. Se eu usar dessa forma, ele altera a virgula para ponto e virgula da primeira linha.
      <script> window.onload = function () { //Check the support for the File API support if (window.File && window.FileReader && window.FileList && window.Blob) { var fileSelected = document.getElementById('txtfiletoread'); fileSelected.addEventListener('change', function (e) { //Set the extension for the file var fileExtension = /text.*/; //Get the file object var fileTobeRead = fileSelected.files[0]; //Check of the extension match if (fileTobeRead.type.match(fileExtension)) { //Initialize the FileReader object to read the 2file var fileReader = new FileReader(); fileReader.onload = function (e) { var pontovirgula = ";"; var virgula = ","; var fileContents = document.getElementById('filecontents'); fileContents.innerText = fileReader.result.replace(virgula, pontovirgula).replace(virgula, pontovirgula); } fileReader.readAsText(fileTobeRead); } else { alert("Por favor selecione arquivo texto"); } }, false); } else { alert("Arquivo(s) não suportado(s)"); } } </script> 7909377852089;1;8380 7909377852133,1,8380 7909377820729,2,8380 7909377820736,2,8380 7909377820743,2,8380 E também, o ultimo valor eu preciso separar os centavos por , virgula.
       
      Arquivo deve ficar dessa forma quando mostrado na pagina.
       
      7909377852089;1;83,80
      7909377852133;1;83,80
      7909377820729;2;83,80
      7909377820736;2;83,80
      7909377820743;2;83,80
       
      Ou seja, contando da direita para esquerda, as duas primeiras posições é o centavos.
       
      Se alguém puder me ajudar, ficarei muito grato.
       
      Att;
      Gilberto Jr
    • Por pandinha_000
      Olá,
      Estou desenvolvendo um código em c++ utilizando manipulação de arquivos .txt (não por ponteiros), e gostaria de saber como fazer para que o algoritmo "pule" a primeira linha em branco do meu arquivo e passe já para a próxima, com dados válidos (na leitura). A propósito, existe a possibilidade de, ao escrever no arquivo, essa primeira linha em branco não exista?
      Desde já agradeço.
    • Por jeffersonmachado
      Olá,
       
      Alguém sabe me dizer porque com o código abaixo o extractto não grava/descompacta o arquivo no diretório?
       
      Grato,
       
       
      <?php
      header('Content-Type: text/event-stream');
      header('Cache-Control: no-cache'); 

      function send_message($id, $message, $progress) {
          $d = array('message' => $message , 'progress' => $progress);
            
          echo "id: $id" . PHP_EOL;
          echo "data: " . json_encode($d) . PHP_EOL;
          echo PHP_EOL;
          //echo str_repeat( ' ', 4096); 
            
          ob_flush();
          flush();
      }
      $path = 'tmp/ripabx_update.zip';
      $versao = file_get_contents("https://repo.results.com.br/repo/ripabx/update/version");
      $zip = new ZipArchive;
      send_message(10,'START', 'Process complete');
      if ($zip->open($path) === true) {
            if ($zip->setPassword($versao)){
                send_message(10,"File $path Num:$zip->numFiles Sta:$zip->status Ver:$versao", "Process complete");
                $previuosProgress = 0;
      $myfile = fopen("testfile.txt", "w");
                for($i = 0; $i < $zip->numFiles; $i++) {
                   if (file_exists($zip->getNameIndex($i))) {
                      unlink($zip->getNameIndex($i));
                   }
                   if ($zip->extractTo('..', array($zip->getNameIndex($i))) === true) {
                      $extrac = "Funcionou";
                   } else {
                      $extrac = "Não Funcionou ";
                   }
                   $progress = round($i / $zip->numFiles * 100);                       
                   if ($progress > $previuosProgress ) {
                      $previuosProgress = $progress;
                      send_message($i, 'on unzip ' . $zip->getNameIndex($i) . ' Ret:' . $extrac, $progress); 
                   }
                }
                $zip->close();
                send_message(10,'CLOSE', 'Process complete');
             } else {
                 send_message(10,'CLOSE', 'Password failed');
             }
      } else {
           send_message(10,'CLOSE', 'Open failed');
      }
      ?>
       
    • Por Daniel Tenorio
      Saudações amigos,
      Minha tabela possui um campo numérico “peso”
      Preciso ler um arquivo txt que está na minha máquina e que contém apenas uma linha com o peso no formato “999999”. Preciso atribuir esse valor no campo do formulário.
      Um detalhe, eu preciso que funcione sem ação do usuário para selecionar o arquivo na pasta, ou seja, que o valor seja atribuído automaticamente ao campo, porém para isso, eu preciso colocar dentro do código (em uma variável) o caminho do arquivo. Ou ao menos se alguém conseguir fazer que funcione com um botão ao lado do campo com a ação do usuário apenas para clicar no botão retornando o valor do txt ao campo já ajudaria muito.
      Consegui fazer o código em anexo funcionar, porém gostaria do preenchimento automático do campo.

×

Informação importante

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