2011-04-20 11 views
5

Dada la siguiente cadena de datos CSV (soy incapaz de asegurar los campos son citados)¿Alguna solución para el error PHP fgetcsv donde se recortan los espacios en blanco?

AB,CD, EF,GH, IJ 

y el código PHP de:

$arr = fgetcsv($f); 

(suponiendo $ f es una lectura de archivos de puntero válido un archivo que contiene el texto anterior) - se podría esperar este resultado:

Array('AB', 'CD', ' EF', 'GH', ' IJ'); 

cuando en realidad se obtiene:

Array('AB', 'CD', 'EF', 'GH', 'IJ'); 

Esto es problemático si necesita un contexto posicional dentro de ese campo.

¿Alguna soluciones temporales de seguir siendo capaz de aprovechar fgetcsv, pero asegurando que no se pierda el espacio en blanco?

El error se informa a continuación: http://bugs.php.net/bug.php?id=53848

+0

Eso es nuevo para mí. El comportamiento PHP es más o menos lo que esperaría. De todas formas, puedes usar 'explotar ('',' '$ línea)' ya que es lo que realmente quieres. – mario

+0

@mario: Pero eso no funciona en todos los casos. –

+0

@mario: Quiero aprovechar fgetcsv cuando sea posible, especialmente con los campos entre comillas si están disponibles. – drowe

Respuesta

6

Oooops. S t.
accidentalmente ya escribió una función que no desnuda los espacios:

function str_getcsv2($line, $del=",", $q='"', $esc="\\") { 
    $line = rtrim($line, "\r\n"); 
    preg_match_all("/\G ([^$q$del]*) $del | $q(([$esc$esc][$q]|[^$q]*)+)$q $del /xms", "$line,", $r); 
    foreach ($r[1] as $i=>$v) { // merge both captures 
     if (empty($v) && strlen($r[2][$i])) { 
      $r[1][$i] = str_replace("$esc$q", "$q", $r[2][$i]); // remove escape character 
     } 
    } 
    return($r[1]); 
} 

usarlo como:

$arr = str_getcsv2(fgets($f)); 
Cuestiones relacionadas