Muchas veces necesitamos modificar partes del core de Joomla, pero si modificamos directamente los archivos nos encontramos con el problema de que al actualizar a una nueva versión de Joomla perderemos los cambios. Pero hay una solución para esto, podemos modificar los archivos desde el template que estamos usando
El otro día un cliente nos hizo el encargo de obtener los países a los que pertenecían un listado de IPs de un log. Bueno, pues usamos cualquier servicio de geolocalización de IPs y solucionado. El problema vino cuando el archivo tenía miles de IPs, de modo que era inviable hacerlo a mano. Así que para estos casos PERL viene de PERLas. Bien, lo primero es tener instalado PERL en nuestra distribución de Linux favorita (sí, PERL se programa en Linux ^_^). Y mediante CPAN instalamos el módulo IP-Country, desde una terminal:
#!/usr/bin/perl
use IP::Country::Fast;
my $ips= "ips.txt"; #Archivo de entrada con una IP en cada línea
my $paises="paises.txt"; #Archivo de salida con el número de IPs por país
open (ENTRADA,"<$ips") or (die "ERROR: No puedo abrir el fichero $ips\n");
open (SALIDA,">$paises") or (die "ERROR: No puedo abrir el fichero $paises\n");
my $reg = IP::Country::Fast->new();
my %hashPaises; # Hash contador de veces que aparece cada país
while (){ #Recorremos línea a línea
$ip=$_;
chomp $ip; #Eliminamos el salto de línea
$pais = $reg->inet_atocc($ip); #Obtenemos el país asociado a la IP
$hashPaises{$pais}++; #Sumamos el contador de país
#print SALIDA ($ip."\t".$pais."\n"); #Si quisieramos imprimir cada IP a qué país pertenece, en mi caso eran demasiadas
}
foreach $pais (sort {$hashPaises{$a} <=> $hashPaises{$b} } keys %hashPaises){ #Imprimimos cada país con su cantidad de ocurrencias ordenado de menor a mayor
print SALIDA "$pais $hashPaises{$pais}\n";
}
close ENTRADA;
close SALIDA;
Si queremos alinear texto al lado de una imagen con HTML y CSS muchas veces nos encontramos con el problema de que no queda alineado del modo que nos interesa, ya que por defecto se alinea abajo. La solución pasa por usar la regla de CSS «vertical-align«, que nos va a permitir que el texto se empiece a escribir en la parte de arriba de la imagen, desde el centro o en la parte inferior.
Por ejemplo:
Alineamos arriba
Alineamos en el centro
Alineamos abajo
Éste es el código CSS usado:
img.alineadoTextoImagenArriba{
vertical-align: text-top;
}
img.alineadoTextoImagenCentro{
vertical-align: middle;
/* Ojo vertical-align: text-middle no existe*/
}
img.alineadoTextoImagenAbajo{
vertical-align: text-bottom;
}
Si por ejemplo quisiéramos alinear el texto en la parte superior podríamos usar el siguiente código HTML:
En uno de nuestros proyectos, la página Web www.movimientosdegenero.com, pensamos junto con la administradora del Blog la idea de una cabecera que cambiase aleatoriamente con cada cambio de página y que además fuese un proyecto participativo (base del 2.0). Lo que hicimos es que los visitantes pudieran enviar su foto y que ésta apareciese tanto en la cabecera de la Web como en una galería. Esta estrategia está acorde con el concepto de Neuromarketing que explicamos en una entrada anterior.
En lo que concierne a la parte técnica, la idea es cargar una imagen diferente cada vez que se llama al archivo PHP que carga el «header». Aunque la página donde lo hemos programado es un WordPress, se puede aplicar en cualquier proyecto Web con PHP. En nuestro caso pusimos el siguiente código en el archivo «header.php» del theme de WordPress:
$carpetaImagenes="rutaDelDirectorio"; //Guardamos todas las posibles cabeceras en el mismo directorio
$directorioImagenes=opendir($carpetaImagenes); //Abrimos el directorio
$cont=0; //Contador del número de imágenes
while ($imagen = readdir($directorioImagenes)) { //Recorremos todas las imagenes del directorio
if($imagen != '.' and $imagen!='..'){ //No tenemos en cuenta el directorio actual (.) y el directorio superior (.)
$imgDir[$cont]=$imagen; //Añadimos la imagen al array
$cont++; //Contamos una más
}
}
sort($imgDir); //Ordenamos el array (en nuestro caso lo necesitamos -> se puede borrar)
$ImgAzar=rand(0, $cont-1); //Elegimos un número aleatorio entre 0 y el número de imágenes (menos uno, que empezamos por cero)
Con el código anterior ya tenemos un array con todas las imágenes del directorio elegido y un número entero aleatorio.
Aunque cada uno lo podéis usar como creáis, en nuestro caso, hemos utilizado el siguiente código HTML para imprimir nuestra cabecera.:
La entrada de hoy va a ser más concreta y técnica que de costumbre. Viene motivada por un proyecto Java con cierta complejidad que estamos acabando y donde muchas de las cosas que hemos programado no tienen documentación (por lo menos en español).
Al grano. Si queremos obtener cual es la fila (row) seleccionada en un jTable de Java utilizamos la función jTable.getSelectedRow() que nos devuelve un entero con la fila seleccionada:
int numFilaSeleccionada=miJTable.getSelectedRow();
Si lo que queremos, es hacer la operación inversa; marcar o seleccionar una fila desde código, es muy tentador hacer (sí, nosotros también lo hemos intentado)
miJTable.getSelectedRow(intFilaSeleccion); //ojo, que esto no funciona
Pero no podía ser tan fácil, la manera correcta de hacerlo es con el modelo de tabla (que aunque no lo hayamos especificado siempre existe uno por omisión):