Удаление файла — пошаговое руководство

Спектр применения различных файлов огромен. Именно поэтому умение их удалять — важный навык. С помощью Python вы можете удалить любой файл на компьютере.

Допустим, вы пишете программу, которая анализирует статистику фондового индекса S&P 500 и записывает ее в файл. Возможно, вы хотите удалить уже существующий файл, чтобы освободить место для нового. 

Метод os.remove() позволит вам удалить файл, а метод os.rmdir() — пустую папку. Если нужно удалить папку вместе с файлами внутри, можно воспользоваться методом shutil.rmtree()

В этом руководстве мы научимся удалять файлы с помощью вышеуказанных методов, а также рассмотрим примеры их использования.

Руководство по удалению файлов

Как уже было сказано, в Python есть несколько методов для удаления файлов — os.remove(), os.rmdir() и shutil.rmtree(). Предназначены они для удаления файлов, директорий и папок с файлами внутри соответственно.

Как удалить файл с помощью метода os.remove()

Метод os.remove() используется для удаления файлов с жесткого диска. Важно: с его помощью нельзя удалить папку, только файл. 

Модуль os позволяет разработчикам работать с операционной и файловой системой компьютера. os.remove — метод для удаления отдельных файлов, встроенный в модуль os

Начать работу с этим методом просто — нужно импортировать модуль os с помощью оператора import.

import os

Теперь мы готовы удалять файлы с помощью метода os.remove(). Рассмотрим синтаксис этого метода: 

import os

os.remove(путь_к_файлу)

Метод os.remove() принимает один параметр — путь к файлу, который мы хотим удалить. 

Допустим, мы пишем программу, которая анализирует оценки учеников математического класса в течение года. 

Наши данные мы будем хранить в файле /home/school/math/final_analysis.csv. Но создавать файл сразу нельзя: возможно, он уже существует.

Чтобы удалить этот файл, можно написать следующую программу:

import os

path = "/home/school/math/final_analysis.csv"

os.remove(path)

print("final_analysis.csv удален.")

Файл удален. Также мы вывели сообщение с помощью оператора print():

final_analysis.csv удален.

В первой строке программы мы импортируем модуль os. В нем содержится метод os.remove(), который мы использовали в нашей программе. Затем мы объявляем переменную path. Эта переменная хранит себе путь к файлу, который мы хотим удалить. 

Затем мы вызываем os.remove() и передаем в качестве аргумента path. После этого происходит удаление файла.

Удаление пустой директории с помощью os.rmdir()

Метод os.remove() не позволяет удалить папку. В этом вам поможет метод os.rmdir(), который используется для удаления пустых файлов и директорий. 

Метод os.rmdir() принимает лишь один параметр — путь к папке, которую вы хотите удалить. Синтаксис этого метода выглядит так: 

import os

os.rmdir(file_path)

Допустим, мы решили хранить наши обработанные данные внутри папки final, которая находится внутри /home/school/math directory. После запуска программы мы эту папку удаляем, ведь создаем точно такую же новую. Для удаления папки final можно написать следующую программу:

import os

path = "/home/school/math/final"

os.rmdir(path)

print("/home/school/math/final удалена.")

Наша программа удаляет директорию /home/school/math/final и печатает в консоль следующее:

/home/school/math/final удалена.

Метод os.rmdir() используется для удаления только пустых директорий. Если внутри папки будут содержаться файлы, программа вернет ошибку: 

[Errno 13] Permission denied: '/home/school/math/final' Directory 'final' can not be removed

Допустим, вы пишете программу для удаления файлов. Вам может понадобиться функция, корректно обрабатывающая ошибки в случае их возникновения. В этом случае вам поможет блок try except.

В примерах выше мы видели, что в некоторых случаях может быть возвращена ошибка (например, если методу не хватает прав для удаления объекта). Если мы используем os.remove() для удаления директории — программа вернет ошибку. И если мы используем os.rmdir() для удаления папки, содержащей файлы, тоже будет возвращена ошибка.

Когда вы пишете программу, удаляющую файлы, вам может понадобиться функция, которая обрабатывает ошибки. Здесь вам пригодится блок except

В примере вы видите использование того же метода os.rmdir(), но с механизмом обработки ошибок. В случае возникновения ошибки этот механизм выводит заранее определенное сообщение.

import os

path = "/home/school/math/final"

try:
    os.rmdir(path)
    print("/home/school/math/final удален.")
except OSError as error:
    print("Возникла ошибка.")

Если мы запустим этот код и ошибок не возникнет, то папка будет удалена и в консоль выведется следующее: 

/home/school/math/final удален.

Но если попытаться удалить тем же способом папку, содержащую файлы, программа выведет в консоль следующее сообщение:

Возникла ошибка.

В нашей программе мы использовали блок except. Выполнение начинается с проверки блока try. Если возникает ошибка — выполняется код внутри блока except. То есть, этот блок выполняется при возникновении ошибки OSError. 

Удаление папки с файлами с помощью shutil.rmtree()

В библиотеке shutil есть метод shutil.rmtree(). Он используется для удаления папок, содержащих файлы. 

Вообще эта библиотека предлагает сразу несколько методов, позволяющих проводить манипуляции с файловой системой. Но сейчас мы поговорим о shutil.rmtree(), с помощью которого можно удалить папку вместе с содержащимися в ней файлами. 

Синтаксис метода shutil.rmtree() выглядит так:

import shutil

shutil.rmtree(file_path)

Обратите внимание — мы импортируем модуль shutil. Как и os.remove(), метод shutil.rmtree() является частью внешнего модуля — именно поэтому мы проводим импорт.

Чтобы лучше понять метод, рассмотрим пример. Допустим, что программа для анализа оценок должна удалить директорию final. Но в ней уже хранятся файлы. Для удаления этой директории и всех файлов в ней мы можем написать следующую программу: 

import shutil

path = "/home/school/math/final"

shutil.rmtree(path)

print("/home/school/math/final удалена.")

Наша программа удаляет папку final и все ее содержимое. После этого в консоль выводится следующее сообщение:

/home/school/math/final удалена.