Extracción de un patrón desde dentro del texto (Microsoft Excel)
Tom tiene una hoja de trabajo que contiene unas 20.000 celdas llenas de datos textuales. Desde dentro de estas celdas, necesita extraer un patrón específico de texto. El patrón es – # donde cada # es un dígito. Este patrón no aparece en un lugar determinado en cada celda. Tom se pregunta si hay alguna forma de extraer la información deseada.
Hay varias formas de abordar este problema, y la solución correcta a sus necesidades dependerá de las características de los datos con los que esté trabajando. Si sabe que el único lugar en sus datos en el que tendrá un guión es dentro de su patrón, puede eliminar la presencia del guión utilizando una fórmula como la siguiente:
=MID(A1,FIND("-",A1)-2,8)
Esto encuentra el guión y luego agarra los ocho personajes comenzando dos caracteres a la izquierda del guión. Obviamente, esto no funcionará si hay guiones en otros lugares del texto o si es posible tener «patrones» que incluyan no dígitos (como 12-34B32) y desea excluirlos. En ese caso, necesitará una fórmula mucho más compleja:
=IF(ISERROR(INT(MID(A1, FIND("-", A1, 1)-2, 2)) & INT(MID( A1, FIND("-", A1, 1)+1, 5))), "", MID(A1, FIND("-", A1)-2, 8))
Esto incluye un componente de verificación de errores que descubre si los caracteres justo antes del guión y justo después del guión contienen algo más que dígitos. Si lo hacen, no se devuelve nada.
Lo único que estos enfoques formulados no hacen es manejar aquellas situaciones en las que puede haber más de una ocurrencia del patrón dentro de la misma celda. En ese caso, una macro es el mejor enfoque. Lo siguiente extraerá los patrones válidos y los colocará en una nueva hoja de trabajo llamada «Resultados».
Sub ExtractPattern() On Error Resume Next Set SourceSheet = ActiveSheet Set TargetSheet = ActiveWorkbook.Sheets("Results") If Err = 0 Then Worksheets("Results").Delete End If Worksheets.Add ActiveSheet.Name = "Results" Set TargetSheet = ActiveSheet Cells(1, 1).Value = "Found Codes" Cells(1, 1).Font.Bold = True iTargetRow = 2 SourceSheet.Select Selection.SpecialCells(xlCellTypeLastCell).Select Range(Selection, Cells(1)).Select For Each c In Selection.Cells If c.Value Like "##-#####" Then sRaw = c.Value iPos = InStr(sRaw, "-") Do While iPos > 0 If iPos < 3 Then sRaw = " " & sRaw iPos = iPos + 2 End If sTemp = Mid(sRaw, iPos - 2, 8) sRaw = Mid(sRaw, iPos + 6, Len(sRaw)) If sTemp Like "##-#####" Then TargetSheet.Cells(iTargetRow, 1) = sTemp iTargetRow = iTargetRow + 1 Else sRaw = Mid(sTemp, 4, 5) & sRaw End If iPos = InStr(sRaw, "-") Loop End If Next c End Sub
Tenga en cuenta que la macro utiliza la función Me gusta en dos lugares. La primera instancia determina si el patrón ocurre en cualquier lugar de la celda, y la segunda instancia se usa para determinar si los caracteres extraídos coinciden exactamente con el patrón deseado.
_Nota: _
Si desea saber cómo usar las macros descritas en esta página (o en cualquier otra página de los sitios ExcelTips), he preparado una página especial que incluye información útil.
link: / excelribbon-ExcelTipsMacros [Haga clic aquí para abrir esa página especial en una nueva pestaña del navegador]
.
ExcelTips es su fuente de formación rentable en Microsoft Excel.
Este consejo (7348) se aplica a Microsoft Excel 97, 2000, 2002 y 2003. Puede encontrar una versión de este consejo para la interfaz de cinta de Excel (Excel 2007 y posterior) aquí:
link: / excelribbon-Extracting_a_Pattern_from_within_Text [Extraer un patrón desde dentro del texto]
.