Ben başka birine dönüştürmek için bir csv dosyası alır bir script kodlama ediyorum. Temelde, iki foreach döngüleri kullanılır: biri alanları yineleme kayıtları ve başka bir yineleme. Her kayıt için belirli alanlar (CNO 25, 26, 44) değiştirilmesi gerekiyor. Sorun her modificatino kodu, yani ekstra boş bir alan yaratmasıdır
$colStr .= '"' . $col . '";';
if ifadeleri de çalışıyor fakat kod herhangi bir.
Kodu:
$rno = 0;
foreach ($csvArray as $line)
{
$cno = 0;
$colStr = "";
foreach ($line as $col)
{
if($rno>0 && $cno==25)
{
$stuff = array($csvArray[$rno][41], $csvArray[$rno][47], $csvArray[$rno][48], $csvArray[$rno][49]);
foreach($stuff as &$value)
{
$value = preg_replace('/[^0-9]/', '', $value);
}
sort($stuff, SORT_NUMERIC);
// Causes bug!
$colStr .= '"' . $stuff[0] . '";';
}
if($rno>0 && $cno==26)
{
$urls = "";
for($i = 55; $i<=62; $i++)
{
$urls .= "Images: " . $csvArray[$rno][$i] . " | ";
}
$urls .= "Some text: " . $csvArray[$rno][43] . " | ";
// Causes bug!
$colStr .= '"' . $urls . '";';
}
if($rno>0 && $cno==44)
{
$colStr .= '"' . $_POST['location'][$rno] . '";';
}
if($rno>0 && $cno==54)
{
$objType = $col;
$objType = preg_replace('/foobar/i', '123', $objType);
// Causes bug!
$colStr .= '"' . $objType . '";';
}
else
{
// This is ok, though
$colStr .= '"' . $col . '";';
}
$cno++;
}
$colStr = preg_replace('/;$/', '', $colStr);
$colStr .= "\n";
fwrite($outputFile, $colStr);
$rno++;
}
fclose($outputFile);