我正在尝试编写一个脚本,允许读取两列.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/>';
}
}
?>
答案 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)
在打开php标签之前删除空格,否则你会得到垃圾空白,当你下载时会在csv中显示headers already sent
错误
删除关闭的php标记,因为它不是必需的,也有助于防止垃圾空白Why do some scripts omit the closing PHP tag, '?>'?
使用fgetcsv(http://php.net/manual/en/function.fgetcsv.php)获取数据
使用fputcsv(http://php.net/manual/en/function.fputcsv.php)来编写数据