繁体   English   中英

fputcsv不适用于特定文件

[英]fputcsv doesn't work with a specific file

我有一个PHP函数,可以将行写入3个不同的CSV文件中:

    if ($fonction == 1)
    {
        $handle = fopen("service_trames_acces.csv", "a");
        $ligne = array($fonction,$groupe,$zone,$no_lecteur,$no_carte, date("d/m/Y"),$date_courante2,$chrono[$no_chrono]['NO_CHRONO'],$cod_typ_acces,$statut,$codeErreur,0);
        fputcsv($handle,$ligne);
        fclose($handle);
    }

    if($fonction == 2)
    {

        $handle = fopen("service_trames_monet.csv", "a");
        $ligne = array($fonction,$groupe,$zone,$no_lecteur,$no_carte,date("d/m/Y"),$date_courante2,$chrono[$no_chrono]['NO_CHRONO'],$cod_typ_monet,$statut,1,$val_nbu_auto,$val_nbu_prec,$codeErreur,0);
        fputcsv($handle,$ligne);
        fclose($handle);
    }
    if($fonction == 3)
    {

        $handle = fopen("service_trames_badg.csv", "a");
        $ligne = array($fonction,$groupe,$zone,$no_lecteur,$no_carte,date("d/m/Y"),$date_courante2,$chrono[$no_chrono]['NO_CHRONO'],self::$entree_sortie,$statut,$codeErreur,0,0);
        fputcsv($handle,$ligne);
        fclose($handle);
    }

第三,如果从不写入文件。

  • fopen返回资源ID
  • fputcsv返回书面行的长度

但是文件始终为空。 我在生产服务器上没有这个问题,只有在测试中,并且如果我使用任何其他文件名,它都可以工作。

谢谢你的帮助 :)

以下评论摘录的片段可能会有所帮助。 确保要写入的文件以及包含的文件夹具有“写入权限”是非常必要的。 以下代码段可确保您具有此权限,但仅在文件级别上。 它使用chmod()实现此目的。 对于包含“文件”的目录,您可以自行确定有效进行分配的方法。

<?php 


    // CREATE AN ARRAY TO MAP $fonction TO SPECIFIC FILES
    $loadableFiles  = [
        1   => "service_trames_acces.csv",
        2   => "service_trames_monet.csv",
        3   => "service_trames_badg.csv",
    ];

    // OPEN A STREAM, AUTOMATICALLY LOADING THE NECESSARY FILE 
    // BASED ON THE VALUE OF $fonction
    $handle         = fopen($loadableFiles[$fonction]);

    // CREATE A BASE ARRAY TO HOLD ALL ENTRIES SHARED ACROSS ALL CASES
    $shared         = [ $fonction, $groupe, $zone, $no_lecteur, 
                        $no_carte, date("d/m/Y"),  $date_courante2, 
                        $chrono[$no_chrono]['NO_CHRONO'] ];

    // INITIALIZE $ligne TO NULL
    $ligne          = null;

    // USING THE VALUE OF $fonction BUILD THE $ligne ARRAY
    switch($fonction){
        case 1;
            $ligne  = [ $cod_typ_acces, $statut, $codeErreur, 0];
            break;
        case 2;
            $ligne  = [ $cod_typ_monet, $statut, 1,  $val_nbu_auto,
                        $val_nbu_prec,  $codeErreur, 0];
            break;
        case 3;
            $ligne  = [ self::$entree_sortie, $statut, $codeErreur, 0, 0];
            break;
    }

    // IF WE HAVE SOME DATA IN THE $ligne ARRAY, THEN WE PROCESS AND SAVE THE CSV
    // TO BE SURE WE HAVE "WRITE-PERMISSION" ON THE FILE; 
    // WE EXPLICITLY GIVE THE PERMISSION AGAIN
    if($ligne) {
        // MERGE $shared WITH $ligne
        $ligne      = array_merge($shared, $ligne);

        // GIVE READ/WRITE PERMISSIONS TO THE FILE OWNER (@LEAST)...
        chmod($loadableFiles[$fonction], 0644);

        // TRY SAVING THE FILE...
        // DUMP THE ERROR MESSAGE ON FAILURE... 
        // YOU MIGHT AS WELL THROW AN EXCEPTION...
        try{                
            fputcsv($handle, $ligne);
        }catch (Exception $e){
            var_dump($e->getMessage());
        }
    }
    // CLOSE THE STREAM
    fclose($handle);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM