Path Utilities (bpy.path)¶
This module has a similar scope to os.path, containing utility functions for dealing with paths in Blender.
-
bpy.path.
abspath
(path, start=None, library=None)¶ Returns the absolute path relative to the current blend file using the “//” prefix.
- Parameters
start (string or bytes) – Relative to this path, when not set the current filename is used.
library (
bpy.types.Library
) – The library this path is from. This is only included for convenience, when the library is not None its path replaces start.
-
bpy.path.
basename
(path)¶ Equivalent to os.path.basename, but skips a “//” prefix.
Use for Windows compatibility.
-
bpy.path.
clean_name
(name, replace='_')¶ Returns a name with characters replaced that may cause problems under various circumstances, such as writing to a file. All characters besides A-Z/a-z, 0-9 are replaced with “_” or the replace argument if defined.
-
bpy.path.
display_name
(name, *, has_ext=True, title_case=True)¶ Creates a display string from name to be used menus and the user interface. Intended for use with filenames and module names.
- Parameters
has_ext – Remove file extension from name
title_case – Convert lowercase names to title case
-
bpy.path.
display_name_to_filepath
(name)¶ Performs the reverse of display_name using literal versions of characters which aren’t supported in a filepath.
-
bpy.path.
display_name_from_filepath
(name)¶ Returns the path stripped of directory and extension, ensured to be utf8 compatible.
-
bpy.path.
ensure_ext
(filepath, ext, case_sensitive=False)¶ Return the path with the extension added if it is not already set.
- Parameters
ext (string) – The extension to check for, can be a compound extension. Should start with a dot, such as ‘.blend’ or ‘.tar.gz’.
case_sensitive (bool) – Check for matching case when comparing extensions.
-
bpy.path.
is_subdir
(path, directory)¶ Returns true if path in a subdirectory of directory. Both paths must be absolute.
- Parameters
path (string or bytes) – An absolute path.
-
bpy.path.
module_names
(path, recursive=False)¶ Return a list of modules which can be imported from path.
- Parameters
path (string) – a directory to scan.
recursive (bool) – Also return submodule names for packages.
- Returns
a list of string pairs (module_name, module_file).
- Return type
list
-
bpy.path.
native_pathsep
(path)¶ Replace the path separator with the systems native
os.sep
.
-
bpy.path.
reduce_dirs
(dirs)¶ Given a sequence of directories, remove duplicates and any directories nested in one of the other paths. (Useful for recursive path searching).
- Parameters
dirs (sequence) – Sequence of directory paths.
- Returns
A unique list of paths.
- Return type
list
-
bpy.path.
relpath
(path, start=None)¶ Returns the path relative to the current blend file using the “//” prefix.
- Parameters
path (string or bytes) – An absolute path.
start (string or bytes) – Relative to this path, when not set the current filename is used.
-
bpy.path.
resolve_ncase
(path)¶ Resolve a case insensitive path on a case sensitive system, returning a string with the path if found else return the original path.