Foros del Web » Programando para Internet » PHP »

no puedo leer de celda de planilla con excel reader

Estas en el tema de no puedo leer de celda de planilla con excel reader en el foro de PHP en Foros del Web. hola a todos. tengo el siguiente problema y necesito de su ayuda. tengo una funcion en la cual leo datos a partir de una planilla ...
  #1 (permalink)  
Antiguo 12/03/2008, 09:52
 
Fecha de Ingreso: enero-2008
Mensajes: 33
Antigüedad: 16 años, 2 meses
Puntos: 0
no puedo leer de celda de planilla con excel reader

hola a todos. tengo el siguiente problema y necesito de su ayuda. tengo una funcion en la cual leo datos a partir de una planilla excel. para esto, uso la funcion excel_reader. la lectura del archivo no tiene inconvenientes pero mi problema empieza despeus del comentario // AQUI PROBLEMA cuando deseo buscar a través de un for, una celda especifica que contiene la cadena "Nombre del Canal". el problema es que no se cumple la condicion en el if (con negritas) la cual deberia buscar la palabra "Nombre del Canal" y a partir de ahi guardar en la variable inicio la posicion de 2 filas mas y por lo tanto no puedo recorrer la planilla a partir de fila en la que deseo. el codigo es el siguiente:


require_once($_SERVER['DOCUMENT_ROOT']."/includes/php/excel_php/reader.php");
//require_once($_SERVER['DOCUMENT_ROOT']."/includes/php/funciones.php");

$excel = new Spreadsheet_Excel_Reader();
$excel->setOutputEncoding("CP1251");
$excel->read($_FILES['archivo']['tmp_name']);

// NUMERO DE FILAS Y COLUMNAS
$inicio = 0;
$posf = 0;
$filas = $excel->sheets[0]['numRows'];
$columnas = $excel->sheets[0]['numCols'];

// FECHA DE INGRESO
$fecha = date("d/m/Y");
$f1_1 = substr($fecha,0,2);
$f1_2 = substr($fecha,3,2);
$f1_3 = substr($fecha,6,4);
$fecha_final = $f1_3."-".$f1_2."-".$f1_1;

$filas_f = $filas - 1;
$columnas_f = $columnas - 1;

echo "Filas: " .$filas;
echo "Columnas: " .$columnas;
echo "filas_f: " .$filas_f;
echo "<br>";


// BUSCANDO LA CELDA "NOMBRE DEL CANAL"
// AQUI PROBLEMA
for($posf = 1; $posf < $filas_f; $posf++ ){

/*
if( (isset( $excel->sheets[0]['cells'][$posf] )) && (isset( $excel->sheets[0]['cells'][$posf][1] )) && ($excel->sheets[0]['cells'][$posf][1] == "Nombre del Canal") ){
echo $excel->sheets[0]['cells'][$posf][1];
$inicio = $posf + 2;
break;
}


if( $excel->sheets[0]['cells'][$posf][1] == "Nombre del Canal" ){
echo $excel->sheets[0]['cells'][$posf][1];
$inicio = $posf + 2;
break;
}
*/
echo $posf;
echo $excel->sheets[0]['cells'][$posf][1] ."<br>";
if( isset( $excel->sheets[0]['cells'][$posf] ) && isset( $excel->sheets[0]['cells'][$posf][1] ) && ($excel->sheets[0]['cells'][$posf][1] == "Nombre del Canal") ){
$inicio = $posf + 1;
break;
}


} // fin for

/*
// OBTENIENDO EL ID DE CADA CANAL SEGUN LOS NOMBRES DE LOS CANALES
$canales = array();
for( $fil = $inicio; $fil < $filas_f; $fil++ ){

$this->db->PConnect();
$variable = $excel->sheets[0]['cells'][$fil][1];
$sql = "SELECT * FROM canales WHERE canal_nombre = '$variable'";
$res = $this->db->GetRow($sql);
if ( $res ) {
$canales[] = $res;
}
$this->db->Close();
}


foreach ($canales as $key => $row) {
echo $this->func->Display($row['id_canal']);
}
*/

echo "valor de la variable inicio: " .$inicio;
echo "valor de filas_f :" .$filas_f;

// MOSTRANDO EL ARCHIVO CARGADO
for( $fil = $inicio; $fil < $filas_f ; $fil++ ){

for($col = 1; $col <= 3 ; $col++){
// COMPROBANDO SI EXISTEN CELDAS N/A, DE EXISTIR
// SE INGRESA UN 0 (CERO)
if( $excel->sheets[0]['cells'][$fil][$col] == "N/A" ){
$excel->sheets[0]['cells'][$fil][$col] = 0;
}
print $excel->sheets[0]['cells'][$fil][$col]."<br>";
} // fin 1° for

//if( empty( $excel->sheets[0]['cells'][$fil][$col] ) || ($excel->sheets[0]['cells'][$fil][$col] == "") ){
// break;
//}

// si existe la fila, fila-columna, si esta vacio
if( isset( $excel->sheets[0]['cells'][$fil] ) && isset( $excel->sheets[0]['cells'][$fil][$col] ) && ($excel->sheets[0]['cells'][$fil][$col] == "") ){
break;
}
echo "\n";

} // FIN FOR MOSTRAR

Necesito su ayuda, o saber en que me estoy equivocando.
de antemano muchas gracias
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 23:37.