Module (73%)
Section (74%)

El método find()

El método find() es similar al método index(), el cual ya conoces - busca una subcadena y devuelve el índice de la primera aparición de esta subcadena, pero:

  • Es más seguro, no genera un error para un argumento que contiene una subcadena inexistente (devuelve -1 en dicho caso).
  • Funciona solo con cadenas - no intentes aplicarlo a ninguna otra secuencia.

Analiza el código en el editor. Así es como puedes usarlo.

El ejemplo imprime:

1 -1

Nota: no se debe de emplear find() si deseas verificar si un solo carácter aparece dentro de una cadena - el operador in será significativamente más rápido.

Aquí hay otro ejemplo:

t = 'teta' print(t.find('eta')) print(t.find('et')) print(t.find('te')) print(t.find('ha'))

¿Puedes predecir la salida? Ejecútalo y verifica tus predicciones.


Si deseas realizar la búsqueda, no desde el principio de la cadena, sino desde cualquier posición, puedes usar una variante de dos parámetros del método find(). Mira el ejemplo:

print('kappa'.find('a', 2))

El segundo argumento especifica el índice en el que se iniciará la búsqueda.

De las dos letras a, solo se encontrará la segunda. Ejecuta el código y verifica.


Se puede emplear el método find() para buscar todas las ocurrencias de la subcadena, como aquí:

txt = """A variation of the ordinary lorem ipsum text has been used in typesetting since the 1960s or earlier, when it was popularized by advertisements for Letraset transfer sheets. It was introduced to the Information Age in the mid-1980s by the Aldus Corporation, which employed it in graphics and word-processing templates for its desktop publishing program PageMaker (from Wikipedia)""" fnd = txt.find('the') while fnd != -1: print(fnd) fnd = txt.find('the', fnd + 1)

El código imprime los índices de todas las ocurrencias del artículo the, y su salida se ve así:

15 80 198 221 238

Existe también una mutación de tres parámetros del método find() - el tercer argumento apunta al primer índice que no se tendrá en cuenta durante la búsqueda (en realidad es el límite superior de la búsqueda).

Observa el ejemplo a continuación:

print('kappa'.find('a', 1, 4)) print('kappa'.find('a', 2, 4))

El segundo argumento especifica el índice en el que se iniciará la búsqueda (no tiene que caber dentro de la cadena).

Por lo tanto, las salidas de ejemplo son:

1 -1

a no se puede encontrar dentro de los límites de búsqueda dados en el segundo print().



Code

# Demostración del método find()
print("Eta".find("ta"))
print("Eta".find("mma"))
{{ dockerServerErrorMsg }} ×
{{ errorMsg }} ×
{{ successMsg }} ×