Foros del Web » Programando para Internet » PHP »

insertar dentro de una tabla en mysql mediante un archivo txt usando php

Estas en el tema de insertar dentro de una tabla en mysql mediante un archivo txt usando php en el foro de PHP en Foros del Web. Hola! Me gustaria que me ayudaran con un pequeño problema que tengo, estoy tratando de llenar una tabla en MySQL obteniendo la información de un ...
  #1 (permalink)  
Antiguo 18/12/2013, 16:25
 
Fecha de Ingreso: diciembre-2013
Ubicación: Distrito Federal
Mensajes: 17
Antigüedad: 5 años, 11 meses
Puntos: 0
Pregunta insertar dentro de una tabla en mysql mediante un archivo txt usando php

Hola!
Me gustaria que me ayudaran con un pequeño problema que tengo, estoy tratando de llenar una tabla en MySQL obteniendo la información de un archivo txt, pero no me deja.
La sintaxis es la siguiente:
<form method="post" action="" enctype="multipart/form-data">
<input type="hidden" id="MAX_FILE_SIZE" name="MAX_FILE_SIZE" value="1000000">
<input type="file" name="nombre" size="40">
<p><input name="submit" type="submit" id="" value="Cargar Archivo"> </p>
</form>
aqui abro la ventana examinar para poder seleccionar el archivo

if($_POST["action"]== "Cargar Archivo"){
$archivo=$_FILES["nombre"]['name'];
if($archivo){
while(!feof($archivo)){
$linea=fgets($archivo,255);
echo $linea;
$sql = "INSERT INTO stockcounts (stockid,qtycounted) ";
$sql .= "VALUES ('$stockid','$qtycounted')";
echo "Registro Añadido<p>";
}
// Enviamos la sentencia SQL al servidor DB
$result = mysql_query($sql);
}
fclose($archivo);
}
este es el código que uso para leer e insertar los datos
  #2 (permalink)  
Antiguo 19/12/2013, 03:06
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 11 años, 8 meses
Puntos: 574
Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

Si haces echo $sql antes de lanzar la consulta veras alguna cosa...

$sql .= "INSERT INTO stockcounts (stockid,qtycounted) ";
$sql .= "VALUES ('$stockid','$qtycounted');";

Eso para obtener un script multi query, el problema es que deberias usar mysqli para que te lo acepte.

La alternativa sin cambiar a mysqli seria

Código PHP:
Ver original
  1. $sql = "INSERT INTO stockcounts (stockid,qtycounted) VALUES ";
  2. while(!feof($archivo)){
  3. $linea=fgets($archivo,255);
  4. echo $linea;
  5. $sql .= "('$stockid','$qtycounted'),";
  6. echo "Registro Añadido<p>";
  7. }
  8. }
  9. // Enviamos la sentencia SQL al servidor DB
  10. $result = mysql_query($sql);
  11. }

Te recomiendo que en tiempo de programacion hagas echo $sql para ver si se ha formatedo bien la query.


Por otro lado el fichero subido esta en tmp_name no en name

Código PHP:
Ver original
  1. <?php
  2. if ($_FILES["file"]["error"] > 0)
  3.   {
  4.   echo "Error: " . $_FILES["file"]["error"] . "<br>";
  5.   }
  6. else
  7.   {
  8.   echo "Upload: " . $_FILES["file"]["name"] . "<br>";
  9.   echo "Type: " . $_FILES["file"]["type"] . "<br>";
  10.   echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
  11.   echo "Stored in: " . $_FILES["file"]["tmp_name"];//<----Aqui
  12.   }
  13. ?>

http://www.w3schools.com/php/php_file_upload.asp
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.

Última edición por quimfv; 19/12/2013 a las 03:12
  #3 (permalink)  
Antiguo 19/12/2013, 09:39
 
Fecha de Ingreso: diciembre-2013
Ubicación: Distrito Federal
Mensajes: 17
Antigüedad: 5 años, 11 meses
Puntos: 0
Pregunta Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

hola quimfv!
if ($_FILES["file"]["error"] > 0)
{
echo "Error: " . $_FILES["file"]["error"] . "<br>";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br>";
echo "Type: " . $_FILES["file"]["type"] . "<br>";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
echo "Stored in: " . $_FILES["file"]["tmp_name"];//<----Aqui
}
ya puse esta parte pero al momento de ejecutar en Size me da 0kb no entiendo la razón o que estoy haciendo mal.
  #4 (permalink)  
Antiguo 19/12/2013, 12:16
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 11 años, 8 meses
Puntos: 574
Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

Código PHP:
Ver original
  1. if($_POST["action"]== "Cargar Archivo"){
  2.     if ($_FILES["nombre"]["error"] > 0){
  3.        echo "Error: " . $_FILES["nombre"]["error"] . "<br>";
  4.     }else{
  5.        echo "Upload: " . $_FILES["nombre"]["name"] . "<br>";
  6.        echo "Type: " . $_FILES["nombre"]["type"] . "<br>";
  7.        echo "Size: " . ($_FILES["nombre"]["size"] / 1024) . " kB<br>";
  8.        echo "Stored in: " . $_FILES["nombre"]["tmp_name"];//<----Aqui
  9.        $archivo=$_FILES["nombre"]["tmp_name"];
  10.        $sql = "INSERT INTO stockcounts (stockid,qtycounted) VALUES ";
  11.        while(!feof($archivo)){
  12.             $linea=fgets($archivo,255);
  13.             echo $linea;//<--- Esto solo muestra la linea no la lee
  14.             $sql .= "('$stockid','$qtycounted'),"; // <--- no veo donde obtienes los valores de las variables.
  15.             echo "Registro Añadido<p>";
  16.         }
  17.         // Enviamos la sentencia SQL al servidor DB
  18.         $result = mysql_query($sql);
  19.    }
  20. }
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.
  #5 (permalink)  
Antiguo 19/12/2013, 13:04
 
Fecha de Ingreso: diciembre-2013
Ubicación: Distrito Federal
Mensajes: 17
Antigüedad: 5 años, 11 meses
Puntos: 0
Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

Ahora probe esto pero se salta hasta el else

$tipo = $_FILES['archivo']['type'];
$tamanio = $_FILES['archivo']['size'];
$archivotmp = $_FILES['archivo']['tmp_name'];
$respuesta = new stdClass();

if( $tipo == 'application/vnd.ms-txt'){

$archivo = "Bibliotecas/Documentos/inventario.txt";

if(move_uploaded_file($archivotmp, $archivo) ){
$respuesta->estado = true;
} else {
$respuesta->estado = false;
$respuesta->mensaje = "El archivo no se pudo subir al servidor, intentalo mas tarde";
}

if($respuesta->estado){

$lineas = file('Bibliotecas/Documentos/inventario.txt');

$respuesta->mensaje = "";
$respuesta->estado = true;
$conexion = new mysqli('localhost','root','srg1887','cambalache',3 306);
foreach ($lineas as $linea_num => $linea)
{
$datos = explode(",",$linea);
$stockid = trim($datos[0]);
$qty = trim($datos[1]);
//$loc=$_POST['Location'];
//$materno = trim($datos[2]);
//$nombre = trim($datos[3]);

$consulta = "INSERT INTO stockcounts(stockid,qtycounted) VALUES('$stockid','$qty'');";
if(!$conexion->query($consulta)){
$respuesta->estado = false;
$respuesta->mensaje .= "El alumno $paterno $materno $nombre no se guardo, verifica la información \n";
}
}
}
if($respuesta->estado == true)
$respuesta->mensaje = "Todos los registros se guardaron correctamente\n";
}
else {
$respuesta->mensaje = "Solo se admiten archivos .txt, vuelvelo a intentar\n"; //<-aqui
}
echo json_encode($respuesta);
  #6 (permalink)  
Antiguo 19/12/2013, 13:46
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 11 años, 8 meses
Puntos: 574
Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

$respuesta->mensaje = "Solo se admiten archivos .txt, vuelvelo a intentar\n"; //<-aqui

Pues serà que no es un .txt???

Código PHP:
Ver original
  1. <?php
  2. $tipo = $_FILES['archivo']['type'];
  3. $tamanio = $_FILES['archivo']['size'];
  4. $archivotmp = $_FILES['archivo']['tmp_name'];
  5. $respuesta = new stdClass();
  6.  
  7. echo "El tipo es? ".$tipo."<br />";
  8.  
  9. if( $tipo == 'application/vnd.ms-txt'){
  10.     $archivo = "Bibliotecas/Documentos/inventario.txt";
  11.     if(move_uploaded_file($archivotmp, $archivo) ){
  12.         $respuesta->estado = true;
  13.     } else {
  14.         $respuesta->estado = false;
  15.         $respuesta->mensaje = "El archivo no se pudo subir al servidor, intentalo mas tarde";
  16.     }
  17.     if($respuesta->estado){
  18.         $lineas = file('Bibliotecas/Documentos/inventario.txt');
  19.         $respuesta->mensaje = "";
  20.         $respuesta->estado = true;
  21.         $conexion = new mysqli('localhost','root','srg1887','cambalache',3306);
  22.         foreach ($lineas as $linea_num => $linea){
  23.             $datos = explode(",",$linea);
  24.             $stockid = trim($datos[0]);
  25.             $qty = trim($datos[1]);
  26.             //$loc=$_POST['Location'];
  27.             //$materno = trim($datos[2]);
  28.             //$nombre = trim($datos[3]);
  29.             $consulta = "INSERT INTO stockcounts(stockid,qtycounted) VALUES('$stockid','$qty'');";
  30.             if(!$conexion->query($consulta)){
  31.                 $respuesta->estado = false;
  32.                 $respuesta->mensaje .= "El alumno $paterno $materno $nombre no se guardo, verifica la información \n";
  33.             }
  34.         }
  35.     }
  36.     if($respuesta->estado == true) $respuesta->mensaje = "Todos los registros se guardaron correctamente\n";
  37. }else {
  38.     $respuesta->mensaje = "Solo se admiten archivos .txt, vuelvelo a intentar\n"; //<-aqui
  39. }
  40. echo json_encode($respuesta);
  41. ?>
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.
  #7 (permalink)  
Antiguo 19/12/2013, 13:54
 
Fecha de Ingreso: diciembre-2013
Ubicación: Distrito Federal
Mensajes: 17
Antigüedad: 5 años, 11 meses
Puntos: 0
Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

Lo tengo guardado con extension txt y no me lo acepta, ya lo intente con otros formatos y saca el mismo mensaje
  #8 (permalink)  
Antiguo 20/12/2013, 07:08
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 11 años, 8 meses
Puntos: 574
Respuesta: insertar dentro de una tabla en mysql mediante un archivo txt usando php

echo "El tipo es? ".$tipo."<br />";

if( $tipo == 'application/vnd.ms-txt')

Has intentado ver si el tipo que da y la condición son iguales....
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.

Etiquetas: archivo.txt, mysql
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 03:43.