Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] PHP OO Cargar info desde un csv

Estas en el tema de Cargar info desde un csv en el foro de PHP en Foros del Web. Hola a todos, tengo una consulta, estoy trabajando en una aplicacion en php que debe tomar datos de un archivo csv. En ese csv cada ...
  #1 (permalink)  
Antiguo 25/01/2013, 11:38
 
Fecha de Ingreso: enero-2013
Mensajes: 21
Antigüedad: 11 años, 3 meses
Puntos: 0
Cargar info desde un csv

Hola a todos, tengo una consulta, estoy trabajando en una aplicacion en php que debe tomar datos de un archivo csv. En ese csv cada fila esta separada por una "," y cada columna por ";" por lo que con el getcsv y el explode lo transformamos en una matriz. La vista utiliza esta matriz para mostrar la info en una tabla y al final de cada fila hay un checkbox, pues el usuario debe escoger cuales filas se cargan a la BD. La pregunta es como le digo a mi controlador cuales seleccionó el usuario??

Este es el codigo de la vista que muestra la informacion en una tabla:
<center><table border='1' class='Lista'>
<?php
for($i=0;$i<count($a_array);$i++){
echo "<tr>";
for($j=0;$j<count($a_array[$i]);$j++){
echo "<td>";
echo $a_array[$i][$j];
echo "</td>";
}echo"<td><input type='checkbox' name='cb_grupo[]' value=$i/></td></tr>";
}
?>
</table>


Gracias por la ayuda...
  #2 (permalink)  
Antiguo 25/01/2013, 12:29
Avatar de skiper0125  
Fecha de Ingreso: octubre-2010
Ubicación: $this->Mexico('Toluca');
Mensajes: 1.127
Antigüedad: 13 años, 6 meses
Puntos: 511
Respuesta: Cargar info desde un csv

Hola que tal.

para lo que deseas hacer se me ocurre lo siguiente:

primero debes de mostrar los datos en input de tal manera que identifiques cada uno de ellos y con la ayuda de javascript puedas habilitar y desabilitar los input para posteriormente guardarlos

Código PHP:

<form action="">
    <table>
        <?php
        
for($i=0;$i<count($a_array);$i++)
        {
            echo 
"<tr>";
            for(
$j=0;$j<count($a_array[$i]);$j++)
            {
                echo 
"<td>";
                    echo 
"<input type=\"text\" name=\"algo_$i\" id=\"algo_$i\" value=\"{$a_array[$i][$j]}\" disabled>"
                echo 
"</td>";
            }
            echo
"<td><input type='checkbox' name='activa_$i' value=\"activa_$i\" onclick=\"activaDatos($i)\"></td></tr>";
        }
        
?>
    </table>
</form>

<script type="text/javascript">
    function activaDatos( arrastre )
    {
        if( documen.getElementById( 'activa_'+arrastre).checked == true )
        {
            //activas los datos
        }
        else
        {
            //desactivas los datos 
        }
    }
</script>

Podría ser una posible solución 

Saludos
__________________
Recuerda que estamos aquí para orientarte, y no para hacer tu trabajo.
Si mi aporte fue de ayuda, recuerda que agradecer no cuesta nada +1

Skiper0125

Última edición por skiper0125; 25/01/2013 a las 12:42
  #3 (permalink)  
Antiguo 25/01/2013, 12:56
 
Fecha de Ingreso: enero-2013
Mensajes: 21
Antigüedad: 11 años, 3 meses
Puntos: 0
Respuesta: Cargar info desde un csv

Ok dejame ver si te capté la idea, lo que haria esto es poner un textfield en cada celda de la tabla para que pueda leer el contenido, el javascript habilita los campos y luego hariamos un ciclo que recorra toda la tabla y obteniendo la información de cada tf, mandándolo linea por linea a la bd.

Ahorra si entendi bien la pregunta seria, la funcion que la recorre igual leeria el contenido de los tf inhabilitados?
Luego no comprendo muy bien de donde viene la variable "arrastre".

Por otro lado cambia algo el hecho de que el archivo csv original esta guardado en un directorio en mi servidor donde talvez lo que tenga que hacer es decirle cuales filas se guardan??

Perdona, no domino mucho la programacion web...

Gracias por la ayuda...

Etiquetas: csv, info, tabla
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 04:35.