
El error FileNotFoundError en Python es uno de los problemas más comunes al trabajar con archivos. Este error ocurre cuando intentamos abrir un archivo que no existe o especificamos una ruta incorrecta. Aunque se trata de un problema frecuente, casi siempre tiene una solución sencilla si aplicamos buenas prácticas en la gestión de archivos.
En esta entrada, explicaremos cómo identificar, resolver y prevenir este error con ejemplos prácticos y funciones útiles que mejorarán el manejo de archivos en Python.
Tabla de contenidos
¿Qué es el error FileNotFoundError?
El error FileNotFoundError se produce cuando Python no puede encontrar el archivo que intentas abrir con la función open()
. Generalmente, esto ocurre si el archivo no existe en la ruta especificada o si la ruta está mal indicada. Sin embargo, también puede deberse a la falta de permisos o al uso incorrecto de rutas relativas.
Por ejemplo, el siguiente código generará este error si el archivo archivo_inexistente.txt
no está en la ruta actual:
with open("archivo_inexistente.txt", "r") as archivo: contenido = archivo.read()
Esto producirá un mensaje de error similar a este:
FileNotFoundError Traceback (most recent call last)
Cell In[12], line 1
----> 1 with open("archivo_inexistente.txt", "r") as archivo:
2 contenido = archivo.read()
Causas más comunes del error FileNotFoundError en Python
Las razones más frecuentes por las que se produce este error en Python son:

- Ruta incorrecta: La ruta proporcionada no corresponde a ningún archivo en el sistema.
- Archivo inexistente: El archivo que intentas abrir no está en el directorio especificado.
- Problemas de permisos: No tienes permisos suficientes para acceder al archivo.
- Uso incorrecto de rutas relativas: Las rutas relativas pueden generar confusión si el directorio de trabajo actual no es el esperado.
Cómo resolver el error FileNotFoundError
A continuación, mostramos una serie de pasos prácticos para identificar la causa que produce este error y cómo solucionarlo de manera eficiente.
Comprueba el directorio de trabajo actual
Si estás utilizando rutas relativas, es esencial conocer en qué directorio se está ejecutando tu script. Puedes verificarlo con la función os.getcwd()
:
import os print("Directorio de trabajo actual:", os.getcwd())
Si el archivo no está en el directorio actual, puedes cambiarlo con os.chdir()
o utilizar rutas absolutas.
Maneja las excepciones con try-except
Si el nombre del archivo lo indica un usuario o si el archivo puede moverse o eliminarse, una buena práctica es usar bloques try-except
para manejar este error y evitar que el programa se interrumpa. Así, si hay un problema con el archivo el programa no se interrumpirá como en el siguiente ejemplo:
try: with open("mi_archivo.txt", "r") as archivo: contenido = archivo.read() except FileNotFoundError: print("El archivo no fue encontrado. Verifica la ruta o su existencia.")
Lo que produce una salida como la siguiente si el archivo no existe:
El archivo no fue encontrado. Verifica la ruta o su existencia.
Crea una función para verificar rutas y permisos
Para manejar archivos de manera segura, puedes crear una función que verifique si el archivo existe, si la ruta es válida y si tienes permisos de lectura. Esto es especialmente útil en programas que necesitan acceder a archivos de manera dinámica, como aplicaciones que procesan datos de usuario o scripts automatizados que dependen de archivos de configuración o registros. De este modo, podemos prevenir errores y garantizar que nuestro programa maneje adecuadamente la ausencia de archivos o la falta de permisos. Facilitando de esta manera el manejo de archivos en las aplicaciones para que estas sean más robustas. Esta función hará tu código más seguro y reutilizable:
import os def verificar_archivo(ruta): """Verifica si un archivo existe, es accesible y tiene permisos. Retorna una tupla (True, None) si el archivo es válido. En caso de error, retorna (False, código de error).""" if not os.path.exists(ruta): return (False, 1) # Código de error 1: El archivo no existe if not os.path.isfile(ruta): return (False, 2) # Código de error 2: La ruta corresponde a un directorio if not os.access(ruta, os.R_OK): return (False, 3) # Código de error 3: No hay permisos de lectura return (True, None) # Archivo válido
Donde la función realiza las siguientes comprobaciones:
os.path.exists(ruta)
: Verifica si la ruta existe en el sistema.os.path.isfile(ruta)
: Confirma que la ruta sea un archivo, no un directorio.os.access(ruta, os.R_OK)
: Verifica si tienes permisos de lectura para el archivo.
Esta función ayuda a prevenir errores antes de intentar abrir un archivo, permitiendo que tu código maneje mejor los posibles problemas de acceso a archivos. Al devolver dos valores, el primero indica si el archivo existe y se puede acceder y el segundo es un código para identidad la causa del problema. El uso de la función es bastante sencillo, tal como se puede ver en el siguiente ejemplo:
ruta = "mi_archivo.txt" es_valido, error = verificar_archivo(ruta) if es_valido: print("El archivo es accesible y válido.") else: print(f"Error en el archivo. Código de error: {error}")
Con lo que se obtiene el siguiente resultado cuando el archivo no existe:
Error en el archivo. Código de error: 1
Conclusiones
El error FileNotFoundError en Python es fácil de solucionar si seguimos buenas prácticas como:
- Verificar las rutas antes de intentar abrir un archivo.
- Utilizar
try-except
para manejar excepciones adecuadamente. - Crear funciones personalizadas para comprobar la existencia de archivos y permisos.
Siguiendo estos consejos, podrás trabajar con archivos en Python de manera segura y eficiente, evitando este error común en tu día a día.
Nota: La imagen de este artículo fue generada utilizando un modelo de inteligencia artificial.
Deja una respuesta