Publicado el Dejar un comentario

Usando fórmulas matriciales o con matrices (arreglos) en Excel. ¿Cuál es su utilidad?

Por lo general, cuando tenemos o hacemos una fórmula en Excel, la hacemos para una celda y luego la copiamos y pegamos en el resto de las celdas Por ejemplo, si tenemos en una columna datos como los precio de un producto y en otra columna la cantidad de artículos de esos producto nos posicionamos en una nueva celda y hacemos la fórmula correspondiente, y luego copiamos esa formula en el resto de la columna; algo así:

=B1*C1
=B2*C2

.. etc.

De esta forma corremos el peligro o de pegar mal la fórmula o de modificarla sin querer con las consecuencias correspondientes.

Con las fórmulas matriciales no sucede eso, ya que si se quiere modificar la fórmula de una celda, Excel nos marcará error y no lo permitirá.

¿Como se crea una fórmula matricial? Siguiendo con el ejemplo anterior:

Selección_427

La columna Total contiene el resultado de multiplicar la Cantidad por el Precio de cada una de las filas. Así es como normalmente lo hacemos. Ahora lo haremos aplicando la Fórmula Matricial. Seleccionamos el rango de Totales, celdas D2 hasta D5 (D2:D5), y escribimos la fórmula de la siguiente manera:

=B2:B5*C2:c5

Y aquí viene lo diferente en lugar de dar solamente  la tecla <Entrar> para guardar la fórmula, usamos la siguiente combinación <Mayús><Ctrl><Entrar>; esta combinación convertirá la formula sencilla a una fórmula matricial:

Selección_428Observe las Llaves ({}) que encierran a la fórmula, estos corchetes indican que ésta es una fórmula matricial. El rango D2:D5 tendrá la misma fórmula. Ahora intentemos cambiar el valor de la celda D2:

Selección_429

Al intentar cambiar el valor a 5 y dar <Entrar>, nos muestra el error de la figura anterior, que nos indica que no podemos cambiar el valor de esa celda ya que pertenece a una matriz. La única forma es seleccionar todo el rango de la matriz y borrar.

Entre otras más aplicaciones de las formulas matriciales esta la siguiente:

Selección_430

En este caso nos sirve para llevar a cabo la sumatoria de los totales de cada producto en un solo paso. Tradicionalmente sacaríamos o calcularíamos primero el total de cada producto y luego una sumatoria de dichos totales para obtener el total total (así se obtuvo la cantidad de la celda D6). Sin embargo utilizando las fórmulas matriciales con una función, en este caso SUMA, podemos obtener el total total en sólo un paso como se obtuvo en la celda C6, como lo muestra la imagen anterior. Para ello se escribió en la celda C6 la función SUMA de esta forma:

SUMA(B2:B5*C2:C5)

Y lo importante, dar la combinación de teclas anteriormente descritas para guardar y convertir esta operación en una fórmula matricial: <Mayús><Ctrl><Entrar>.

Espero y les sirva este tip.  ¡No olvides visitar a los anunciantes!

¡Gracias!

 

Publicado el Dejar un comentario

Remover apóstrofos de los datos en Excel.

A veces cuando importamos datos a una hoja de excel nos encontramos con que datos numéricos o fechas no son reconocidos como tales por el excel.

Si observamos en la casilla de contenido de la celda vemos que a la fecha o al número le antecede un apóstrofo como se muestra en la imagen siguiente:

Selección_415

Esto le indica a excel que trate el contenido de la celda como si fuera texto. En este caso no reconoce como fecha el dato y por lo tanto ordenar por fecha y otras operaciones por fecha no funcionarán. Lo mismo sucederá si el contenido después del apostrofe es un número; no será reconocido como tal. Buscar y reemplazar no funcionará así que se hace lo siguiente:

Selecciona las celdas a las cuales se le quiere elimina el apóstrofo y seleccionamos DATOS -> Texto en columnas -> Finalizar como se muestra en la imagen siguiente:

Selección_416

Al terminar, en este caso, las fechas se alinearán a la derecha y serán reconocidas como tales por excel. El mismo procedimiento funciona con datos numéricos.

Espero y les sea útil este consejo. No te olvides de visitar a los patrocinadores del sitio dando clik en los anuncios.

¡Gracias!

Publicado el Dejar un comentario

java.lang.IllegalStateException: getOutputStream() has already been called for this response. Glassfish 4.1.1.

Desde hace un tiempo, utilizo Glassfish como servidor de aplicaciones en mis desarrollos web con Java. Sin embargo en el proyecto que actualmente trabajo, al descargar la última versión y querer añadir un nuevo pool de conexiones, la consola de administración gráfica de Glassfish 4.1.1 me arroja el siguiente error:

java.lang.IllegalStateException: getOutputStream() has already been called for this response.

Buscando la causa me encuentro que es un bug en esta nueva versión de Glassfish que aún no ha sido resuelto. Hay que recordar que Oracle dejó de dar soporte sobre este producto y por lo tanto, las correcciones de errores son más lentas que antes. En el misma dirección donde se reporta este bug se indica algunas soluciones.

Dentro de las soluciones, me enteré que existe una empresa que ha empezado otro desarrollo en base al código de Glassfish y realiza funciones de mantenimiento más prontas: Payara Server. Lo he descargado y funciona perfectamente hasta el momento. De ahora en adelante utilizaré este servidor de aplicaciones en futuros desarrollos.

¡Felices fiestas!

(Por favor visita a los patrocinadores).