Python: Difference between os.remove() and os.unlink() and which one to use?
Solution 1
They are identical as described in the official Python 2.7.15 documentation.
Remove (delete) the file path. If path is a directory, OSError is raised; see rmdir() below to remove a directory. This is identical to the unlink() function documented below. On Windows, attempting to remove a file that is in use causes an exception to be raised; on Unix, the directory entry is removed but the storage allocated to the file is not made available until the original file is no longer in use.
Availability: Unix, Windows.
Remove (delete) the file path. This is the same function as remove(); the unlink() name is its traditional Unix name.
Availability: Unix, Windows.
Solution 2
When using pathlib.Path
file access in Python v3.4 and higher
While the question specifically asks for the os
module file removal, the latest versions of Python have another option for removing files that may be an alternative.
Direct Answer - use pathlib.Path.unlink()
- Note:
pathlib.Path.remove()
does not exist
When using the pathlib module for file access, use pathlib.Path.unlink()
to remove files.
The Path.unlink()
method is a replacement for both os.remove()
and os.unlink()
. It is executed directly on a Path object, rather than being passed the location of a file through a string argument.
More details
Starting in Python v3.4 the pathlib
builtin module is available to handle file access in an object-oriented manner. I believe a separate package is also available via Pip for older versions of Python.
With pathlib, you create folder and file objects that are of the Path
class. The related method of removing a file has been consolidated to just unlink()
. They do not have a remove()
method (likely because, per shash678's answer, there is no difference, it's just an alias). This appears to be equivalent to the os
methods of file deletion, other than the underlying means of specifying the file itself.
See Object Oriented file system paths, along with the table at the bottom that shows both os.remove()
and os.unlink()
map to Path.unlink()
.
In Python v3.8, a missing_ok argument was added to the Path.unlink()
function. When *missing_ok* == True
, an exception will not be raised if the file doesn't exist before trying to remove it.

NoName
Updated on July 05, 2022Comments
-
NoName 11 months
I have a number of files in a folder. I want to delete each file once it has been processed.
What's the difference between using
os.remove()
andos.unlink
? Which method is ideal for my scenario? -
David Skarbrevik over 4 yearsWhy do they both exist then? Is "unlink" so idiomatic to warrant a completely redundant function?
-
little_birdie over 4 years@DavidSkarbrevik Well.. WIndows people are used to remove(), unix people are used to unlink.. but also.. unlink() implies the unix filesystem behavior. When you unlink a file in unix, you aren't necessarily deleting it.. only deleting the specific hard link. If that hard link happens to be the only (or last remaining) link, then yes the file will cease to exist. With FAT/FAT32, when you delete a file it's gone, not just the link. With NTFS it's more sophisticated but still different. But basically unlink() is a unix thing and implies the unix behavior which isn't the same as Windows.
-
Mark Amery over 3 yearsCuriously, the Python 3 docs now describe the two functions as "semantically identical" (rather than simply "identical" or "the same function"). I also notice that
os.remove is os.unlink
is False, so they're not just distinct names for the same function object (though may have identical implementations). I wonder what's going on under the hood... -
anthony sottile over 3 years@MarkAmery the reason the python 3 docs describe it that way is because I raised a bug report :) -- they used to be identical (read:
os.unlink is os.remove
) but after they were redone with argument clinic they are now two separate functions -- bugs.python.org/issue25930 -
zardosht about 1 yearNice answer. But is not the answer to OP's question. That's why you have to SHOUT in the first line.
-
LightCC about 1 year@zardosht Agreed that the answer is ancillary, which is why a header is all the more useful to readers, so they can quickly decide whether this answer addresses aspects of the question they are interested in or not. I feel most answers longer than a few lines would benefit from headers and other formatting flare.