为什么我的fputcsv不工作?

时间:2017-02-17 13:22:33

标签: php arrays fputcsv

我无法使PHP内置函数fputcsv()起作用。这是我尝试过的:

error_reporting(E_ALL);
ini_set('display_errors', 1);

include('DBConn.php');              //My SQL server connection information
include 'Helper/LogReport.php';     //Keeps a count of how many times reports are exported


$query = $conn->query("SELECT QName, tsql from pmdb.QDefs WHERE QName = '" .$TableName. "'");
$query->execute();
$qdef = $query->fetch(PDO::FETCH_ASSOC);


// Create and open file for writing
$filepath = 'exports/';
$filename = $qdef['QName'] . '.csv';
try
{
    header('Content-Encoding: UTF-8');
    header('Content-Type: text/csv; charset:UTF-8');
    header('Content-Disposition: attachment; filename="' . $filename . '"');
    //$openFile = fopen('php://output','w');
    $openFile = fopen($filepath . $filename,'w');
}
catch(Exception $e)
{
    echo "Something went wrong<br>";
    die( print_r( $e->getMessage()));
}

//define separators
$sep = ",";     //separator
$br = "\r\n";   //line break

// Use returned tsql field as query for dataset
$tsql = $qdef['tsql'];
if(isset($DataReturn))
{
    if(strpos($DataReturn['Order'],'EDIT'))
    {
        $DataReturn['Order'] = str_replace('EDIT','Id',$DataReturn['Order']);
    }
    $tsql = $tsql . $DataReturn['WhereClause'] . $DataReturn['Order'] . $DataReturn['Limit'];
}

$query = $conn->query($tsql);
$query->execute();

// Output data to CSV file
$headers = NULL;
while ($row = $query->fetch(PDO::FETCH_ASSOC))
{
    //Write column headings to file
    if (is_null($headers))
    {
        $headers = array_keys((array)$row);
        if ($headers[0] == 'ID')
            $headers[0] = 'Id';
        fputcsv($openFile, $headers, ',','"');

    }
    //Write data
    $modRow = preg_replace('/ \d{2}:\d{2}:\d{2}\.\d{3}/', '', array_values($row));
    $modRow = preg_replace( "/\r|\n/", "", $modRow );
    /*
    $modRow = str_replace('\r\n', " ", $modRow);
    $modRow = str_replace('\n\r', " ", $modRow);
    $modRow = str_replace('\n', " ", $modRow);
    $modRow = str_replace('\r', " ", $modRow);
    $modRow = str_replace(' ', " ", $modRow);
    $modRow = str_replace('Â ', " ", $modRow);
    $modRow = str_replace('"', '', $modRow);
    $modRow = str_replace("'", "", $modRow);
    */
    fputcsv($openFile, $modRow, ',','"');
}

// Close file
fclose($openFile);

但是没有任何内容打印到文件中,它只是空白。我设置错了吗?

修改

我已经尝试了fopen上我可以在this page找到的每个变体,但是在使用fputcsv时他们都给了我一个空白文件。我只在echo数组时获取文件中的数据。

END OF EDIT

您可以看到标头数组是从查询返回到数据库的数组键设置的。我可以echo他们并获得正确的标题。

然后有自己的数据行。我删除了不需要的字符,但它们仍然是数据数组,应该使用fputcsv进行打印。我再次通过循环遍历数组的内容echo。这就是我现在让出口工作的方式,但我知道这只是一种解决方法,希望让fputcsv正常工作。

这就是我打印行的方式:

foreach($modRow as $RowPrint)
{
    echo '"' .trim(unserialize(serialize($RowPrint))). '"' .$sep;
}
echo $br;

更新

以下是我print_r标题时的输出:

Array
(
    [0] => Id
    [1] => QSRC
    [2] => QNAME
    [3] => QDEF
    [4] => ISACTIVE
    [5] => RUNREPORT
    [6] => FILEPATH
    [7] => TSQL
)

这是我print_r $modRow时的一行:

Array
(
    [Id] => 60
    [QSRC] => bau
    [QNAME] => Oops I deleted this!
    [QDEF] => SELECT REGION
    [ISACTIVE] => 0
    [RUNREPORT] => 0
    [FILEPATH] => 
    [TSQL] => 
)

print_r之后fputcsv应该将它们打印到文件中。这些是文件中的唯一内容。

2 个答案:

答案 0 :(得分:1)

我删除了第一个答案,因为它不正确。

******************* EDIT *******************

您需要将其添加到文件的末尾:

exit();

这告诉浏览器您已完成对文件的写入,并确保出于安全原因没有向浏览器发送额外内容。

答案 1 :(得分:0)

您不能使用php:// stdout将输出发送到浏览器。您可以使用php:// memory来存储字符串,然后将其读回。

    var divs = [];
    nodeArray.forEach(function(array, index) {
        divs[index] = nodeArray[index].children;
    });

    var imgs = [];
    for (var x = 0; x < divs.length; x++) {
        imgs[x] = [];
        for (var y = 0; y < divs[x].length; y++) {
            imgs[x][y] = divs[x][y].childNodes[0];
        }
    }