• Saltar al contenido principal
  • Skip to secondary menu
  • Saltar a la barra lateral principal
  • Saltar al pie de página
  • Inicio
  • Secciones
    • Ciencia de datos
    • Criptografía
    • Herramientas
    • Machine Learning
    • Noticias
    • Opinión
    • Productividad
    • Programación
      • JavaScript
      • Julia
      • Matlab
      • Python
      • R
  • Programación
    • JavaScript
    • Julia
    • Matlab
    • Python
    • R
  • Laboratorio
    • Encuestas: Tamaño de Muestra
    • Lotería: Probabilidad de Ganar
    • Reparto de Escaños (D’Hondt)
    • Tres en Raya con IA
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad
    • Tiendas afiliadas
      • AliExpress
      • Amazon
      • Banggood
      • GeekBuying
      • Lenovo

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • IA Generativa
  • Python
  • Pandas
  • NumPy
  • Excel
  • Matlab

FileNotFoundError en Python: Guía para abrir archivos correctamente en Python

febrero 10, 2025 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 4 minutos

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

  • 1 ¿Qué es el error FileNotFoundError?
  • 2 Causas más comunes del error FileNotFoundError en Python
  • 3 Cómo resolver el error FileNotFoundError
    • 3.1 Comprueba el directorio de trabajo actual
    • 3.2 Maneja las excepciones con try-except
    • 3.3 Crea una función para verificar rutas y permisos
  • 4 Conclusiones

¿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()

Publicidad


Causas más comunes del error FileNotFoundError en Python

Las razones más frecuentes por las que se produce este error en Python son:

Curiosidad: La maldición de la dimensionalidad, o por qué añadir más datos puede empeorar tu modelo
En Analytics Lane
Curiosidad: La maldición de la dimensionalidad, o por qué añadir más datos puede empeorar tu modelo

  1. Ruta incorrecta: La ruta proporcionada no corresponde a ningún archivo en el sistema.
  2. Archivo inexistente: El archivo que intentas abrir no está en el directorio especificado.
  3. Problemas de permisos: No tienes permisos suficientes para acceder al archivo.
  4. 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.

Publicidad


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.

Publicidad


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:

  1. os.path.exists(ruta): Verifica si la ruta existe en el sistema.
  2. os.path.isfile(ruta): Confirma que la ruta sea un archivo, no un directorio.
  3. 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.

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

Puntuación promedio 0 / 5. Votos emitidos: 0

Ya que has encontrado útil este contenido...

¡Síguenos en redes sociales!

¡Siento que este contenido no te haya sido útil!

¡Déjame mejorar este contenido!

Dime, ¿cómo puedo mejorar este contenido?

Publicidad


Publicaciones relacionadas

  • Curiosidad: La maldición de la dimensionalidad, o por qué añadir más datos puede empeorar tu modelo
  • ¿Está concentrado el MSCI World? Un análisis con Gini, Lorenz y leyes de potencia
  • Curiosidad: ¿Por qué usamos p < 0.05? Un umbral que cambió la historia de la ciencia
  • Programador de tareas de Windows: Guía definitiva para automatizar tu trabajo (BAT, PowerShell y Python)
  • La Paradoja del Cumpleaños, o por qué no es tan raro compartir fecha de nacimiento
  • Cómo abrir una ventana de Chrome con tamaño y posición específicos desde la línea de comandos en Windows
  • Curiosidad: El sesgo de supervivencia, o por qué prestar atención sólo a los que “llegaron” puede engañarte
  • Documentar tu API de Express con TypeScript usando OpenAPI (Swagger)
  • Data Lake y Data Warehouse: diferencias, usos y cómo se complementan en la era del dato

Publicado en: Python

Interacciones con los lectores

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

I accept the Terms and Conditions and the Privacy Policy

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

Barra lateral principal

Suscríbete a nuestro boletín

Suscríbete al boletín semanal para estar al día de todas las publicaciones.

Política de Privacidad

Analytics Lane en redes sociales

  • Amazon
  • Bluesky
  • Facebook
  • GitHub
  • Instagram
  • Mastodon
  • Pinterest
  • RSS
  • Telegram
  • Tumblr
  • Twitter
  • YouTube

Publicidad

Entradas recientes

Data Lake y Data Warehouse: diferencias, usos y cómo se complementan en la era del dato

octubre 23, 2025 Por Daniel Rodríguez

Documentar tu API de Express con TypeScript usando OpenAPI (Swagger)

octubre 21, 2025 Por Daniel Rodríguez

Curiosidad: El sesgo de supervivencia, o por qué prestar atención sólo a los que “llegaron” puede engañarte

octubre 16, 2025 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Hoja de cálculo para repartir los escaños en base al método D’Hont Aplicar el método D’Hondt en Excel publicado el abril 14, 2021 | en Herramientas
  • Cómo solucionar problemas de red en VirtualBox: Guía completa publicado el junio 11, 2025 | en Herramientas
  • Cómo calcular el tamaño de la muestra para encuestas publicado el septiembre 9, 2025 | en Ciencia de datos
  • La tabla de la web finalmente importada en Excel Importar tablas desde la web en Excel publicado el octubre 21, 2020 | en Herramientas
  • pandas Pandas: Cómo iterar sobre las filas de un DataFrame en Pandas publicado el septiembre 13, 2021 | en Python

Publicidad

Lo mejor valorado

4.9 (24)

Seleccionar filas y columnas en Pandas con iloc y loc

4.6 (16)

Archivos JSON con Python: lectura y escritura

4.4 (14)

Ordenación de diccionarios en Python mediante clave o valor

4.7 (13)

Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas

4.5 (10)

Diferencias entre var y let en JavaScript

Publicidad

Comentarios recientes

  • Daniel Rodríguez en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • Pepe en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • CARLOS ARETURO BELLO CACERES en Justicio: La herramienta gratuita de IA para consultas legales
  • Piera en Ecuaciones multilínea en Markdown
  • Daniel Rodríguez en Tutorial de Mypy para Principiantes

Publicidad


Footer

Analytics Lane

  • Acerca de Analytics Lane
  • Boletín de noticias
  • Contacto
  • Libros
  • Lo más popular
  • Noticias
  • Tienda
  • Tiendas afiliadas

Secciones

  • Ciencia de datos
  • Criptografía
  • Herramientas
  • Machine Learning
  • Opinión
  • Productividad
  • Programación
  • Reseñas

Sobre de Analytics Lane

En Analytics Lane tratamos de explicar los principales conceptos de la ciencia e ingeniería de datos con un enfoque práctico. Los principales temas tratados son ciencia de datos, ingeniería de datos, inteligencia artificial, machine learning, deep learning y criptografía. Además, también se habla de los principales lenguajes de programación y herramientas utilizadas por los científicos e ingenieros de datos.

Copyright © 2018-2025 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto