safe_path()¶
- audeer.safe_path(path, *paths, follow_symlink=False)[source]¶
Expand and normalize to absolute path.
It uses
os.path.realpath()
andos.path.expanduser()
to ensure an absolute path without..
or~
, and independent of the path separator of the operating system. Iffollow_symlink
isFalse
, the fasteros.path.abspath()
is used instead ofos.path.realpath()
.Warning
audeer.safe_path()
is deprecated, please useaudeer.path()
instead.- Parameters
- Return type
- Returns
(joined and) expanded path
Examples
>>> home = audeer.safe_path("~") >>> folder = audeer.safe_path("~/path/.././path") >>> folder[len(home) + 1 :] 'path' >>> file = audeer.safe_path("~/path/.././path", "./file.txt") >>> file[len(home) + 1 :] 'path/file.txt' >>> file = audeer.touch("file.txt") >>> link = audeer.path("link.txt") >>> os.symlink(file, link) >>> os.path.basename(audeer.path(link)) 'link.txt' >>> os.path.basename(audeer.path(link, follow_symlink=True)) 'file.txt'