La función XLOOKUP es exclusiva del programa interno de Office 365. La función LOOKUP tiene muchas funcionalidades que superan muchas de las debilidades de la función VLOOKUP y HLOOKUP, pero lamentablemente no está disponible para nosotros por ahora. Pero no se preocupe, podemos crear una función XLOOKUP que funcione exactamente igual que la próxima función XLOOKUP MS Excel. Le añadiremos funcionalidades una a una.
Código VBA de la función XLOOKUP
La siguiente función de búsqueda de UDF resolverá muchos problemas. Cópielo o descargue el complemento xl a continuación.
Función XLOOKUP (lk como variante, lCol como rango, rCol como rango) XLOOKUP = WorksheetFunction.Index (rCol, WorksheetFunction.Match (lk, lCol, 0)) End Function
Explicación:
El código anterior es solo INDEX-MATCH básico utilizado en VBA. Esto simplifica muchas de las cosas a las que se enfrenta un nuevo usuario. Si resuelve la complejidad de la función INDEX-MATCH y usa solo tres argumentos. Puede copiarlo en su archivo de Excel o descargar el archivo .xlam a continuación e instalarlo como un complemento de Excel. Si no sabe cómo crear y usar un complemento, haga clic aquí, lo ayudará.
Complemento XLOOKUP
veamos cómo funciona en la hoja de cálculo de Excel.
Sintaxis de XLOOKUP
= XLOOKUP (lookup_value, lookup_array, result_array) |
valor de búsqueda: Este es el valor que desea buscar en el lookup_array.
lookup_array: Es un rango unidimensional en el que desea buscar el valor de búsqueda.
matriz_resultados: También es un rango unidimensional. Este es el rango del que desea recuperar el valor.
Veamos esta función XLOOKUP en acción.
Ejemplos de XLOOKUP:
Aquí, tengo una tabla de datos en Excel. Exploremos algunas funciones usando esta tabla de datos.
Funcionalidad 1. Exacto Busque en el lado izquierdo y derecho del valor de búsqueda.
Como sabemos, la función BUSCARV de Excel no puede recuperar valores de la izquierda del valor de búsqueda. Para eso, debe usar la compleja combinación INDICE-MATCH. Pero ya no más.
Suponiendo que necesitamos recuperar toda la información disponible en la tabla de algunos números de rollo. En ese caso, también tendrá que recuperar la región, que se encuentra a la izquierda de la columna del número de rollo.
Escribe esta fórmula, I2:
= XLOOKUP (H2, $ B $ 2: $ B $ 14, $ A $ 2: $ A $ 14) |
Obtenemos el resultado Norte para el rollo número 112. Copie o arrastre hacia abajo la fórmula en las celdas de abajo para llenarlas con las regiones respectivas.
¿Como funciona?
El mecanismo es simple. Esta función busca el valor de búsqueda en lookup_array y devuelve el índice de una primera coincidencia exacta. Luego usa ese índice para recuperar el valor de matriz_resultados. Esta función funciona perfectamente con rangos con nombre.
De manera similar, use esta fórmula para recuperar el valor de cada columna.
Funcionalidad 2. Exacto Horizontal Busque arriba y abajo del valor de búsqueda.
XLOOKUP también funciona como una función HLOOKUP exacta. La función BUSCARH tiene la misma limitación que la BUSCARV. No puede obtener un valor por encima del valor de búsqueda. Pero XLOOKUP no solo funciona como HLOOKUP, también supera esa debilidad. Veamos cómo.
Hipotéticamente, si desea comparar dos registros. El registro de búsqueda que ya tiene. El registro con el que desea comparar está por encima de lookup_range. Utilice esta fórmula en ese caso.
= BUSCAR X (H7, $ A $ 9: $ E $ 9, $ A $ 2: $ E $ 2) |
arrastre hacia abajo la fórmula y tendrá el registro completo de la fila de comparación.
Funcionalidad 3. No es necesario el número de columna y la coincidencia exacta predeterminada.
Cuando utiliza la función BUSCARV, debe indicar el número de columna desde el que desea obtener los valores. Para eso, tienes que contar las columnas o usar algunos trucos, toma la ayuda de otras funciones. Con esta UDF XLOOKUP, no necesita hacer eso.
Si está utilizando BUSCARV para simplemente obtener algún valor de una columna o para verificar si existe un valor en la columna, esta es la mejor solución en mi opinión.
Funcionalidad 4. Reemplaza la función INDEX-MATCH, VLOOKUP, HLOOKUP
Para tareas simples, nuestra función XLOOKUP reemplaza las funciones mencionadas anteriormente.
Limitaciones de XLOOKUP:
Cuando se trata de fórmulas complejas, como VLOOKUP con Dynamic Col Index, donde VLOOKUP identifica la columna de búsqueda con encabezados, esta XLOOKUP fallará.
Otra limitación es que si tiene que buscar varias columnas o filas aleatorias en la tabla, esta función será inútil ya que tendrá que escribir esta fórmula una y otra vez. Esto se puede solucionar utilizando rangos con nombre.
Por ahora, no hemos agregado la funcionalidad aproximada, por lo que, por supuesto, no puede obtener la coincidencia aproximada. Agregaremos eso demasiado pronto.
Si la función BUSCAR X no encuentra el valor de búsqueda, devolverá el error #VALOR, no # N / A.
Así que sí, chicos, así es como usan XLOOKUP para recuperar, buscar y validar valores en tablas de Excel. Puede utilizar esta función definida por el usuario para una búsqueda sin problemas a la izquierda o hacia arriba del valor de búsqueda. Si aún tiene alguna duda o algún requisito específico relacionado con esta función o EXCEL 2010/2013/2016/2019/365 o consulta relacionada con VBA, pregúntelo en la sección de comentarios a continuación. Seguramente obtendrá una respuesta.
Crear función VBA para devolver matriz | Para devolver una matriz de una función definida por el usuario, tenemos que declararla cuando nombramos la UDF.
Matrices en Excel Formul | Aprenda qué son las matrices en Excel.
Cómo crear una función definida por el usuario a través de VBA »Wiki Ùtil Aprenda a crear funciones definidas por el usuario en Excel
Usando una función definida por el usuario (UDF) de otro libro usando VBA en Microsoft Excel | Utilice la función definida por el usuario en otro libro de Excel
Devolver valores de error de funciones definidas por el usuario usando VBA en Microsoft Excel | Descubra cómo puede devolver valores de error desde una función definida por el usuario
Articulos populares:
Divida la hoja de Excel en varios archivos según la columna mediante VBA | Esta hoja de Excel dividida en código VBA se basa en valores únicos en una columna específica. Descarga el archivo de trabajo.
Desactivar los mensajes de advertencia mediante VBA en Microsoft Excel 2016 | Para desactivar los mensajes de advertencia que interrumpen el código VBA en ejecución, usamos la clase Application.
Agregar y guardar un libro nuevo con VBA en Microsoft Excel 2016 | Para agregar y guardar libros de trabajo usando VBA usamos la clase Workbooks. Workbooks.Add agrega un nuevo libro fácilmente, sin embargo …