Foros del Web » Programando para Internet » PHP »

Problemas con TILDES en php con MySQL

Estas en el tema de Problemas con TILDES en php con MySQL en el foro de PHP en Foros del Web. Buenas tardes, una vez mas necesito de su ayuda para terminar mi interfaz. La cosa es asi, el usuario tendrá que seleccionar un archivo CSV ...
  #1 (permalink)  
Antiguo 16/03/2010, 10:19
 
Fecha de Ingreso: marzo-2008
Mensajes: 25
Antigüedad: 11 años, 8 meses
Puntos: 0
Problemas con TILDES en php con MySQL

Buenas tardes, una vez mas necesito de su ayuda para terminar mi interfaz.
La cosa es asi, el usuario tendrá que seleccionar un archivo CSV con determinada estructura para cargar la tabla de contacto en una base MySQL.
El problema es el siguiente, en el campo Observaciones, el texto viene con tildes de esta forma : á é í ó ú, entonces, cuando mi consulta encuentra algun caracter de estos, corta y pasa a la siguiente linea y asi sucesivamente. Es decir, si encuentra en observaciones un texto que dice "Esto es una frase con tílde" solamente agrega a la base de datos "Esto es una frase con t" y salta a la siguiente linea.
Les adjunto aqui algunos datos del CSV y el php que carga los datos a la base a ver si me pueden dar una manito con el codigo, o bien, decirme que necesito ponerle a ese campo en la base MySQL. Actualmente ese campo en la base esta como utf8_spanish_ci.

Código PHP:
Ver original
  1.     $nombre_archivo = $_FILES['userfile']['name'];
  2.     $temporal=$_FILES['userfile']['tmp_name'];
  3.     $extension=$_FILES['userfile']['type'];
  4.     if ($extension!="application/vnd.ms-excel"){
  5.         $error_carga="ERROR : El archivo a cargar debe ser en formato .CSV";
  6.     }else{
  7.         move_uploaded_file($temporal,'./CargasClientes/'.$nombre_archivo);
  8.         $conn=mysql_connect("localhost","root","3ntradA");
  9.         $row = 1;
  10.         $fp = fopen("./CargasClientes/".$nombre_archivo,"r");
  11.         while ($data = fgetcsv($fp,4000,",")){
  12.             $num = count($data);
  13.             $row++;
  14.             $insertar="INSERT INTO contacto (CodContacto,CodCliente,Fecha,Hora,Asesor,Resultado,Motivo,Observaciones) VALUES ('$data[0]','$data[1]','$data[2]','$data[3]','$data[4]','$data[5]','$data[6]','$data[7]')";
  15.             $resultado=mysql_db_query("banred",$insertar);
  16.         }
  17.         fclose($fp);
  18.         if ($resultado=="1"){
  19.             $error_carga="Carga OK";
  20.         }else{
  21.             $error_carga="Ocurrio un error en la carga de Contactos. Intentelo denuevo mas tarde";
  22.         }
  23.     }          
  24.     header ('Location:../Administracion/I_Carga.php?tablacargada=Contacto&errorcarga='.$error_carga.'&totalcarga='.$row);


MUCHAS GRACIAS !!!!
  #2 (permalink)  
Antiguo 17/03/2010, 05:26
Avatar de Bytevamp  
Fecha de Ingreso: junio-2005
Ubicación: /var/www/
Mensajes: 789
Antigüedad: 14 años, 5 meses
Puntos: 7
Respuesta: Problemas con TILDES en php con MySQL

Prueba asi:
Código PHP:
$insertar="INSERT INTO contacto (CodContacto,CodCliente,Fecha,Hora,Asesor,Resultado,Motivo,Observaciones) VALUES ('$data[0]','$data[1]','$data[2]','$data[3]','$data[4]','$data[5]','$data[6]','".utf8_encode($data[7])."')"
Y a ver si te vale( si no prueba a usar htmlentities).

Un saludo.
__________________
"zankius veri mach" a todos los que me habeis ayudado.
carteles para inmobiliarias || alquiler de coches
  #3 (permalink)  
Antiguo 17/03/2010, 08:15
 
Fecha de Ingreso: marzo-2008
Mensajes: 25
Antigüedad: 11 años, 8 meses
Puntos: 0
Respuesta: Problemas con TILDES en php con MySQL

Código PHP:
Ver original
  1. echo "MUCHAS GRACIAS !! ME HAS SALVADO LA VIDA !!!";




Etiquetas: mysql, tildes
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 17:48.