Categorí­a: 'PHP - MySQL'

Decodificando desde ASCII, ISO 8859-1 o UTF-8 (Y 2)

Completando la utilidad anterior que os dimos, os proponemos estas dos pequeñas  funciones que también nos ahorrarán mucho tiempo y código llegado el caso.

Estas dos funciones hace un fetch (de objetos o arrays) sobre una query anterior, pero además nos cambia la codificación de los textos obtenidos de una sóla vez. Consiguiendo así olvidarnos de escribir en la linea del echo un utf8-decode(fila->texto ), htmlenties($fila[’texto’]), etc.

# Hace un fetch de query devolviendo el objeto reformateado
#
#
function mysql_fetch_object_dfw($query){
	
   $objeto=mysql_fetch_object($query);
	
   if($objeto){
	
      foreach(get_object_vars($objeto) AS $ind => $val){
	
         $val=($val==NULL)? '': $val;
         $objeto->$ind	=	decode_for_web($val);
	
      }
	
   }
	
   return $objeto;
	
}
	
# Hace un fetch de query devolviendo el array reformateado
#
#
	
function mysql_fetch_array_dfw($query){
	
   $array_o=mysql_fetch_array($query);
	
   if($array_o){
	
      foreach($array_o AS $ind => $val){
         $val=($val==NULL)? '': $val;
         $array_o[$ind]=decode_for_web($val);
      }
	
   }
	
   return $array_o;
	
}

Añadir Comentario May 9th, 2008

Decodificando desde ASCII, ISO 8859-1 o UTF-8

A todo programador PHP le llega el momento de lidiar con la temible codificación de caracteres al crear una web. Cosas llamadas ISO 8859, UTF, Latin1, JIS. etc… pueden volverte loco si no se ha tenido en cuenta a la hora de crear las BBDD, incluir script de terceros, wordpress, google maps, etc…

Como ayuda hemos tratado de crear una pequeña función para ayudarte a despreocuparte de todo. Ella sólo detecta la codificación del texto pasado y obra en consecuencia, lo cual puede ser muy util si estamos trabajando con caracteres de los que desconocemos su codificación, o peor aún, ¡Tienen codificaciones mezcladas!

<?php
	
# Probamos 3 cadenas de texto con diferentes codificaciones
# la primera con caracteres ASCII (hasta el 128)
# la segunda ISO 8859-1 latin1 (con una eñe)
# y la tercera con el caracter copuright en formato utf8
#
	
//Array donde almacenaremos el resultado de la funcion:
$salida	=	array();
$salida[]	=	decode_for_web("2mdc");
$salida[]	=	decode_for_web("diseño");
$salida[]	=	decode_for_web("WEB ©");
	
//Pintamos la tabla:
echo '<table border="1">';
foreach($salida AS $valor){
	
	echo	'<tr><td>'.$valor[0].'</td>';
	echo	'<td>'.$valor[1].'</td></tr>';
	
}
echo '</table>';
	
# Funcion decodificadora desde ASCII, Latin1 o UTF-8
# Es muy importante conservar el orden del 2do parametro
# en mb_detect_encoding para su correcto funcionamiento.
#
	
function decode_for_web($texto){
	
	$tipo = mb_detect_encoding($texto, "ASCII,UTF-8,
		ISO-8859-1");
	
	switch($tipo){
	
		case "ASCII":
	
		break;
		case "UTF-8":
			$texto	=	utf8_decode($texto);
		break;
		case "ISO-8859-1":
	
		break;
		default:
	
		break;
	
	}
	
	//array con el texto decodificado y su tipo.
	return array($texto,$tipo);
	
}
	
?>

Como se puede ver utilizamos la nativa mb_detect_encoding() la cual es algo rara a la hora de configurar.
Se puede añadir código en las diferentes casos del switch o al final para por ejemplo convertir a entidades HTML antes retornar.

El resultado sería éste:

2mdc ASCII
diseño ISO-8859-1
WEB © UTF-8

Añadir Comentario May 9th, 2008

Búsqueda bruta en MySQL

Aunque no debiera ser así, en ocasiones se nos presenta la situación de buscar cierta palabra o cadena de caracteres en una base de datos sin saber siquiera en que columna o tabla se encuentra. Ante esta necesidad nos surgió hacer esta pequeña herramienta de emergencia, con la que podemos buscar cualquier cadena dentro de cualquier base de datos MySQL, sin la necesidad de crear una consulta SQL con todas las columnas por cada tabla. (Tarea que puede ser desesperante).

El siguiente código tiene 3 pantallas:

La primera de acceso a la base de datos en la que introduciremos la IP donde esté escuchando el servidor (o localhost si estamos en una maquina local), el usuario, la contraseña y la base de datos que queremos examinar.

En la segunda podremos señalar las tablas donde queremos buscar entre todas las que existen e introducir una cadena a buscar.

Y por fin en la tercera pantalla nos aparecerán los registros que tengan coincidencias resaltando la cadena buscada ordenados por tablas.

El código está comentado y podreis adaptarlo, modificarlo y mejorarlo todo lo que querais.

Descargar de 2mdc.Com

Entradas relacionadas: De MySQL a Excel

Añadir Comentario May 4th, 2007

De MySQL a Excel

La verdad es que el título ya lo dice casi todo.

Desde aquí os podéis descargar una sencilla aplicación que vuelca bases de datos MySQL en archivos Excel.

La aplicación utiliza la compatibilidad XML de las última versiones de Microsoft Office.

El volcar la base de datos en un archivo XML compatible Excel permite, por ejemplo:

  • Guardar diferentes tablas en diferentes hojas
  • Dar formato al archivo Excel resultante mediante hojas de estilo, lo que facilita su legibilidad
  • Hacerle la pelota al jefe presentándole los datos en la única aplicación que jamas ha aprendido a utilizar

El zip de descarga incluye un pequeño archivo de texto con comentarios aclaratorios. Esperamos los vuestros…

Descargar de 2mdc.Com

NOTA: No hemos conseguido convencer a Ricardo (el responsable de haber hecho los scripts) de que cambie el diseño de la página de entrada de la aplicación.
2mdc.com no se hace responsable del mismo :-)

Entradas relacionadas: Búsqueda bruta en MySQL

Añadir Comentario February 15th, 2006

Modificación de archivos Multiple

Descripción:
Ultimamente nos hemos encontrado con la necesidad de agregar los conocidos ‘headers y footers’ a nuestras webs, por eso desarrollamos esta mini-aplicación open-source con la que conseguiremos modificar recursivamente todos los archivos de la extensión que queramos que esten en un directorio, agregandoles una cabecera y un pie.

Descargar de 2mdc.Com

Como funcionalidad extra también nos brinda la posibilidad de sustituir una cadena de texto o una expresion regular por la cadena de texto que queramos.

La aplicacion esta zipeada. Se compone de:

  • 1html con el formulario donde introducir los parametros
  • 1php que es el script que procesa los archivos
  • 1header y 1footer de ejemplo

Añadir Comentario December 30th, 2005

  Sabías que...
 
Sabías que...

... ya somos más de 1000 millones de internautas.

Hace tan solo 3 años se estimaban en poco más de 600 millones el número de internautas, lo que supone una tasa de incremento anual del 18%.

¿Aún sigue pensando que su empresa puede vivir de espaldas a Internet?

 
 
2mdc.com diseño web     C/ Matias Turrión, 24, 1º, Madrid 28043      Tel: 91 759 00 24       Fax 91 759 15 18     Contacto