nukescripts.Path

class nukescripts.Path(*args, **kwargs)[source]

Bases: pathlib.PurePath

PurePath subclass that can make system calls.

Path represents a filesystem path but unlike PurePath, also offers methods to do system calls on path objects. Depending on your system, instantiating a Path will return either a PosixPath or a WindowsPath object. You can also instantiate a PosixPath or WindowsPath directly, but cannot instantiate a WindowsPath on a POSIX system or vice versa.

Construct a PurePath from one or several strings and or existing PurePath objects. The strings and path objects are combined so as to yield a canonicalized path, which is incorporated into the new PurePath object.

Methods

absolute

Return an absolute version of this path by prepending the current working directory.

as_posix

Return the string representation of the path with forward (/) slashes.

as_uri

Return the path as a 'file' URI.

chmod

Change the permissions of the path, like os.chmod().

cwd

Return a new path pointing to the current working directory (as returned by os.getcwd()).

exists

Whether this path exists.

expanduser

Return a new path with expanded ~ and ~user constructs (as returned by os.path.expanduser)

glob

Iterate over this subtree and yield all existing files (of any kind, including directories) matching the given relative pattern.

group

Return the group name of the file gid.

hardlink_to

Make this path a hard link pointing to the same file as target.

home

Return a new path pointing to the user's home directory (as returned by os.path.expanduser('~')).

is_absolute

True if the path is absolute (has both a root and, if applicable, a drive).

is_block_device

Whether this path is a block device.

is_char_device

Whether this path is a character device.

is_dir

Whether this path is a directory.

is_fifo

Whether this path is a FIFO.

is_file

Whether this path is a regular file (also True for symlinks pointing to regular files).

is_mount

Check if this path is a POSIX mount point

is_relative_to

Return True if the path is relative to another path or False.

is_reserved

Return True if the path contains one of the special names reserved by the system, if any.

is_socket

Whether this path is a socket.

is_symlink

Whether this path is a symbolic link.

iterdir

Iterate over the files in this directory.

joinpath

Combine this path with one or several arguments, and return a new path representing either a subpath (if all arguments are relative paths) or a totally different path (if one of the arguments is anchored).

lchmod

Like chmod(), except if the path points to a symlink, the symlink's permissions are changed, rather than its target's.

link_to

Make the target path a hard link pointing to this path.

lstat

Like stat(), except if the path points to a symlink, the symlink's status information is returned, rather than its target's.

match

Return True if this path matches the given pattern.

mkdir

Create a new directory at this given path.

open

Open the file pointed by this path and return a file object, as the built-in open() function does.

owner

Return the login name of the file owner.

read_bytes

Open the file in bytes mode, read it, and close the file.

read_text

Open the file in text mode, read it, and close the file.

readlink

Return the path to which the symbolic link points.

relative_to

Return the relative path to another path identified by the passed arguments.

rename

Rename this path to the target path.

replace

Rename this path to the target path, overwriting if that path exists.

resolve

Make the path absolute, resolving all symlinks on the way and also normalizing it.

rglob

Recursively yield all existing files (of any kind, including directories) matching the given relative pattern, anywhere in this subtree.

rmdir

Remove this directory.

samefile

Return whether other_path is the same or not as this file (as returned by os.path.samefile()).

stat

Return the result of the stat() system call on this path, like os.stat() does.

symlink_to

Make this path a symlink pointing to the target path.

touch

Create this file with the given access mode, if it doesn't exist.

unlink

Remove this file or link.

with_name

Return a new path with the file name changed.

with_stem

Return a new path with the stem changed.

with_suffix

Return a new path with the file suffix changed.

write_bytes

Open the file in bytes mode, write to it, and close the file.

write_text

Open the file in text mode, write to it, and close the file.

Attributes

anchor

The concatenation of the drive and root, or ''.

drive

The drive prefix (letter or UNC path), if any.

name

The final path component, if any.

parent

The logical parent of the path.

parents

A sequence of this path's logical parents.

parts

An object providing sequence-like access to the components in the filesystem path.

root

The root of the path, if any.

stem

The final path component, minus its last suffix.

suffix

The final component's last suffix, if any.

suffixes

A list of the final component's suffixes, if any.

absolute()[source]

Return an absolute version of this path by prepending the current working directory. No normalization or symlink resolution is performed.

Use resolve() to get the canonical path to a file.

property anchor

The concatenation of the drive and root, or ‘’.

as_posix()

Return the string representation of the path with forward (/) slashes.

as_uri()

Return the path as a ‘file’ URI.

chmod(mode, *, follow_symlinks=True)[source]

Change the permissions of the path, like os.chmod().

classmethod cwd()[source]

Return a new path pointing to the current working directory (as returned by os.getcwd()).

property drive

The drive prefix (letter or UNC path), if any.

exists()[source]

Whether this path exists.

expanduser()[source]

Return a new path with expanded ~ and ~user constructs (as returned by os.path.expanduser)

glob(pattern)[source]

Iterate over this subtree and yield all existing files (of any kind, including directories) matching the given relative pattern.

group()[source]

Return the group name of the file gid.

Make this path a hard link pointing to the same file as target.

Note the order of arguments (self, target) is the reverse of os.link’s.

classmethod home()[source]

Return a new path pointing to the user’s home directory (as returned by os.path.expanduser(‘~’)).

is_absolute()

True if the path is absolute (has both a root and, if applicable, a drive).

is_block_device()[source]

Whether this path is a block device.

is_char_device()[source]

Whether this path is a character device.

is_dir()[source]

Whether this path is a directory.

is_fifo()[source]

Whether this path is a FIFO.

is_file()[source]

Whether this path is a regular file (also True for symlinks pointing to regular files).

is_mount()[source]

Check if this path is a POSIX mount point

is_relative_to(*other)

Return True if the path is relative to another path or False.

is_reserved()

Return True if the path contains one of the special names reserved by the system, if any.

is_socket()[source]

Whether this path is a socket.

Whether this path is a symbolic link.

iterdir()[source]

Iterate over the files in this directory. Does not yield any result for the special paths ‘.’ and ‘..’.

joinpath(*args)

Combine this path with one or several arguments, and return a new path representing either a subpath (if all arguments are relative paths) or a totally different path (if one of the arguments is anchored).

lchmod(mode)[source]

Like chmod(), except if the path points to a symlink, the symlink’s permissions are changed, rather than its target’s.

Make the target path a hard link pointing to this path.

Note this function does not make this path a hard link to target, despite the implication of the function and argument names. The order of arguments (target, link) is the reverse of Path.symlink_to, but matches that of os.link.

Deprecated since Python 3.10 and scheduled for removal in Python 3.12. Use hardlink_to() instead.

lstat()[source]

Like stat(), except if the path points to a symlink, the symlink’s status information is returned, rather than its target’s.

match(path_pattern)

Return True if this path matches the given pattern.

mkdir(mode=511, parents=False, exist_ok=False)[source]

Create a new directory at this given path.

property name

The final path component, if any.

open(mode='r', buffering=- 1, encoding=None, errors=None, newline=None)[source]

Open the file pointed by this path and return a file object, as the built-in open() function does.

owner()[source]

Return the login name of the file owner.

property parent

The logical parent of the path.

property parents

A sequence of this path’s logical parents.

property parts

An object providing sequence-like access to the components in the filesystem path.

read_bytes()[source]

Open the file in bytes mode, read it, and close the file.

read_text(encoding=None, errors=None)[source]

Open the file in text mode, read it, and close the file.

Return the path to which the symbolic link points.

relative_to(*other)

Return the relative path to another path identified by the passed arguments. If the operation is not possible (because this is not a subpath of the other path), raise ValueError.

rename(target)[source]

Rename this path to the target path.

The target path may be absolute or relative. Relative paths are interpreted relative to the current working directory, not the directory of the Path object.

Returns the new Path instance pointing to the target path.

replace(target)[source]

Rename this path to the target path, overwriting if that path exists.

The target path may be absolute or relative. Relative paths are interpreted relative to the current working directory, not the directory of the Path object.

Returns the new Path instance pointing to the target path.

resolve(strict=False)[source]

Make the path absolute, resolving all symlinks on the way and also normalizing it.

rglob(pattern)[source]

Recursively yield all existing files (of any kind, including directories) matching the given relative pattern, anywhere in this subtree.

rmdir()[source]

Remove this directory. The directory must be empty.

property root

The root of the path, if any.

samefile(other_path)[source]

Return whether other_path is the same or not as this file (as returned by os.path.samefile()).

stat(*, follow_symlinks=True)[source]

Return the result of the stat() system call on this path, like os.stat() does.

property stem

The final path component, minus its last suffix.

property suffix

The final component’s last suffix, if any.

This includes the leading period. For example: ‘.txt’

property suffixes

A list of the final component’s suffixes, if any.

These include the leading periods. For example: [‘.tar’, ‘.gz’]

Make this path a symlink pointing to the target path. Note the order of arguments (link, target) is the reverse of os.symlink.

touch(mode=438, exist_ok=True)[source]

Create this file with the given access mode, if it doesn’t exist.

Remove this file or link. If the path is a directory, use rmdir() instead.

with_name(name)

Return a new path with the file name changed.

with_stem(stem)

Return a new path with the stem changed.

with_suffix(suffix)

Return a new path with the file suffix changed. If the path has no suffix, add given suffix. If the given suffix is an empty string, remove the suffix from the path.

write_bytes(data)[source]

Open the file in bytes mode, write to it, and close the file.

write_text(data, encoding=None, errors=None, newline=None)[source]

Open the file in text mode, write to it, and close the file.