使用 fgetcsv 函数后,从 ftp 服务器读取下载的文件不是填充数据


Reading a downloaded file from ftp server is not shoing data after using fgetcsv function

我正在使用cURL请求从FTP服务器下载CSV文件。

我已经将我的文件下载到我的网络根文件夹中(在我的给定路径中)。

但是当我尝试从文件中读取CSV数据时,它没有显示任何内容。 $leadDir是我下载文件的路径。

if ($fp = fopen($leadDir, "r")) {
    echo $fp;
    echo "come after fopen";
    while ($CSVData = fgetcsv($fp)) {
        echo "</br>";
        echo "come after fgetcsv";
    }
}

它不会进入while循环。

我还检查了文件权限,我给了它 777 个权限。

哪里出了问题?

代码应该没问题,所以我最好的答案是路径不正确,尝试类似

$cwd = getcwd();
$leadDir = $cwd.'/relativePathToFile';
if(file_exists($leadDir)){
    if (($fp = fopen($leadDir, "r"))) {
        echo $fp;
        echo "come after fopen";
        while ($CSVData = fgetcsv($fp)) {
            echo "</br>";echo "come after fgetcsv";
        } 
    }
 }

你的代码看起来应该可以工作了。这是我将使用的代码:

<?php
if($handle = fopen('test.csv', 'r')) {
    $data = fgetcsv($handle);
    if($data) {
        echo '<pre>';
        var_dump($data);
        echo '</pre>';
    }
}
?>

尝试执行以下代码:

var_dump(file_exists($leadDir));

如果文件存在,它将输出

bool(true)

否则将输出

bool(false)

另外,$leadDir目录还是文件

如果提供了无效的句柄,fgetcsv() 返回 NULL,或者在其他错误(包括文件末尾)时返回 FALSE。

尝试:

if (($fp = fopen($leadDir, "r")) !== FALSE) {
    echo $fp;
    echo "come after fopen";
    while (($CSVData = fgetcsv($fp,1000,',')) !== FALSE) {
        echo "</br>";
        echo "come after fgetcsv";
    }
}

如果它仍然没有进入 while 循环,请尝试检查 CSV 的文件末尾。

注意:如果 PHP 在读取 Macintosh 计算机上的文件或由 Macintosh 计算机创建的文件时无法正确识别行尾,则启用auto_detect_line_endings运行时配置选项可能有助于解决问题。(来源 PHP.net)

检查目标目录的所有者。尝试向www-data用户授予权限。

您可以通过对下载的文件使用 chown 函数以编程方式执行此操作。

这是语法。

bool chown ( string $filename , mixed $user )