使用PHP和Postgresql导出CSV

时间:2014-01-14 18:04:22

标签: php postgresql csv fatal-error

我正在使用这个课程:

<?php

class csv{
private $separador;
private $cabecalho;
private $dados;
private $path;
private $arquivo;

public function csv($separador=null, $cabecalho=null, $dados="", $path="", $arquivo="csv"){
    #seta as propriedades
    $this->separador = $separador;
    $this->cabecalho = $cabecalho;
    $this->dados = $dados;
    $this->path = $path;
    $this->arquivo = $arquivo;
}
public function salvar(){
    #gera string de cabeçalho
    $colunas = "";
        foreach($this->cabecalho as $coluna){
            if ($colunas == ""){
            $colunas .= $coluna;
            } else {
            $colunas .= $this->separador.$coluna;
            }
        }
    $saida[] = $colunas;
    #gera string do corpo do arquivo
    foreach ($this->dados as $linha){
        #pega as variaveis do array
        $colunasDados = "";
        foreach($linha as $coluna){
            if ($colunasDados == ""){
            $colunasDados .= $coluna;
            } else {
            $colunasDados .= $this->separador.$coluna;
            }
        }
        $saida[] = $colunasDados;
}

    #verifica se alguma linha foi inserida
    if(count($saida)>1){
        #monta o corpo do CSV
        $corpo = implode("\n", $saida);
        #abre um arquivo para escrita, se o arquivo não existir ele tenta criar
        $fp = fopen ($this->path.$this->arquivo.".csv", "w");// W = sobrescreve
        if($fp <> NULL){
            #escreve no arquivo
            fwrite($fp, $corpo);
            #fecha o arquivo
            fclose($fp);
            #retorno do sistema
            echo "<p>Pronto</p>";
                        } 
            else {
            echo "<p>Verifique se a pasta ou o arquivo tem permissão para escrita!</p>";
                    }
     } 
      else {
        echo "<p>Sem linhas para importação!</p>";
            }
    }

导出csv文件。

这是旋转的我的文件:

 <?php
#chama classe
include("program.class.php");
$objeto = new csv();
#Executa os selects         
$tijuca = $objeto->selecionaTijuca();
#gera cabeçalho
$cabecalho = array("mes","ano","titulobanco","matricula");
#cria instancia de objeto da classe
$tijuca = new CSV (";", $cabecalho, $tijuca,"pasta/Nova/", "cotas");
$tijuca->salvar();

&GT;

我遇到了这个记忆问题:

Fatal error: Allowed memory size of 524288000 bytes exhausted (tried to allocate 262144 bytes) in .../program.class.php on line 42

我已经看到一些能够使用此命令编辑php内存的解决方案:

ini_set("memory_limit","500M");

但它没有解决,并使我的服务器超载。 任何人都知道如何在不重载的情况下导出csv文件? 或者在我的程序中有什么问题?

抱歉我的英文。

谢谢

1 个答案:

答案 0 :(得分:1)

查看postgresql copy命令。它可以选择直接输出CSV。