Last modified: Mar 22, 2025 By Alexander Williams

Python Pathlib touch() Explained

The pathlib.touch() method in Python is a powerful tool for file handling. It allows you to create or update files with ease. This guide will walk you through its usage, syntax, and examples.

What is pathlib.touch()?

The touch() method is part of Python's pathlib module. It creates a new file at the specified path if it doesn't exist. If the file already exists, it updates the file's modification time.

This method is particularly useful when you need to ensure a file exists before performing operations on it. It simplifies file creation and management in your Python scripts.

Syntax of pathlib.touch()

The syntax for pathlib.touch() is straightforward. Here’s how it looks:


from pathlib import Path

# Create a Path object
file_path = Path('example.txt')

# Use touch() to create or update the file
file_path.touch()

In this example, example.txt will be created if it doesn't exist. If it does, its modification time will be updated.

Parameters of pathlib.touch()

The touch() method accepts two optional parameters:

  • mode: Sets the file mode (permissions). Default is 0o666.
  • exist_ok: If True, no exception is raised if the file exists. Default is True.

These parameters give you control over file permissions and behavior when the file already exists.

Example: Creating a New File

Let’s create a new file using pathlib.touch():


from pathlib import Path

# Define the file path
file_path = Path('new_file.txt')

# Create the file
file_path.touch()

print(f"File created: {file_path.exists()}")


File created: True

This code creates new_file.txt in the current directory. The exists() method confirms the file's creation.

Example: Updating an Existing File

If the file already exists, touch() updates its modification time:


from pathlib import Path
import time

# Define the file path
file_path = Path('existing_file.txt')

# Create the file if it doesn't exist
file_path.touch()

# Get the initial modification time
initial_time = file_path.stat().st_mtime

# Wait for a second
time.sleep(1)

# Update the modification time
file_path.touch()

# Get the updated modification time
updated_time = file_path.stat().st_mtime

print(f"Initial time: {initial_time}")
print(f"Updated time: {updated_time}")


Initial time: 1698765432.1234567
Updated time: 1698765433.1234567

Here, the modification time of existing_file.txt is updated after calling touch().

Practical Use Cases

The touch() method is useful in various scenarios:

  • File Initialization: Ensure a file exists before writing data.
  • Log Rotation: Update modification times for log files.
  • File Synchronization: Track file changes in scripts.

For more advanced file operations, check out Python Pathlib stat() Explained.

Handling Errors

By default, touch() does not raise an error if the file exists. However, you can control this behavior with the exist_ok parameter:


from pathlib import Path

# Define the file path
file_path = Path('example.txt')

# Create the file
file_path.touch(exist_ok=False)

If exist_ok is False, an exception is raised if the file already exists.

Conclusion

The pathlib.touch() method is a simple yet powerful tool for file management in Python. It ensures files exist and updates their modification times effortlessly.

For more insights into file handling, explore Python Pathlib write_text() Explained and Python Pathlib read_text() Explained.

Start using pathlib.touch() in your projects today to streamline file operations!