来自csv的PHP file_get_contents()和file_put_contents

时间:2013-07-09 13:37:34

标签: php image csv file-get-contents

我正在尝试编写一个脚本,允许读取两列.csv文件(带名称的第一列,带图像URL的第二列),然后将图像保存到我的硬盘驱动器中列作为保存的文件名。我能够保存一些图像(所有文件都已创建,但有些文件丢失了)。命名约定以我想要的方式工作,但我需要获取所有文件。有人想看看吗?可能值得一提的是我正在使用MAMP,但.csv中的图像地址都是有效的(我用标​​签回显了图像地址,所以我知道它们有效)。

<?php
    //header('Content-Description: File Transfer');
    //header('Content-Disposition: attachment; filename ='
    //Eli's 2 column CSV grab-n-save file

    $file = 'Random.csv'; //put file path of .csv here
    $buffer = file_get_contents($file);
    //print_r($buffer);
    $pattern = '/[,\n]/';

    $catch = preg_split($pattern, $buffer);
    $keep_track = 0;

    foreach($catch as $value)
    {
        if ($keep_track%2 == 0)
        {
        //if first column is sku
            $name = $value;
            $keep_track += 1;
        }
        elseif ($keep_track %2 == 1)
        {
            //if an image
            $name = str_replace(' ', '',$name);

            //Change pathname to MAMP specs
            $name2 =  '/Applications/MAMP/htdocs/picturegrab' . $name . '.jpg';

            file_put_contents($name2, file_get_contents($value), FILE_APPEND);
            //echo $value . '<br/>';
            $keep_track += 1;

            echo $name2 . '<br/>' . '<img src='.$value.'><br/>';
        }

    }
?>

2 个答案:

答案 0 :(得分:0)

一些逻辑

$file = fopen('Random.csv');
$dir = '/Applications/MAMP/htdocs/picturegrab/';
while (list($name, $img_link) = fgetcsv($file)) {
  $name = str_replace(" ", "", $name);
  copy($img_link, $dir.$name.'.jpg');
}

更新了我的示例以使其更具响应性

对于 Sam Green 与他的屁眼

答案 1 :(得分:0)

  1. 在打开php标签之前删除空格,否则你会得到垃圾空白,当你下载时会在csv中显示headers already sent错误

  2. 删除关闭的php标记,因为它不是必需的,也有助于防止垃圾空白Why do some scripts omit the closing PHP tag, '?>'?

  3. 使用fgetcsv(http://php.net/manual/en/function.fgetcsv.php)获取数据

  4. 使用fputcsv(http://php.net/manual/en/function.fputcsv.php)来编写数据