[英]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);
}
第三,如果从不写入文件。
但是文件始终为空。 我在生产服务器上没有这个问题,只有在测试中,并且如果我使用任何其他文件名,它都可以工作。
谢谢你的帮助 :)
以下评论摘录的片段可能会有所帮助。 确保要写入的文件以及包含的文件夹具有“写入权限”是非常必要的。 以下代码段可确保您具有此权限,但仅在文件级别上。 它使用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.