os.path — Common pathname manipulations

Source code: Lib/posixpath.py (for POSIX) and Lib/ntpath.py (for Windows).


Цей модуль реалізує деякі корисні функції для шляхів. Щоб прочитати або записати файли, перегляньте open(), а для доступу до файлової системи перегляньте модуль os. Параметри шляху можна передати як рядки, або байти, або будь-який об’єкт, що реалізує протокол os.PathLike.

Unlike a unix shell, Python does not do any automatic path expansions. Functions such as expanduser() and expandvars() can be invoked explicitly when an application desires shell-like path expansion. (See also the glob module.)

Дивись також

Модуль pathlib пропонує об’єкти шляху високого рівня.

Примітка

Усі ці функції приймають як параметри лише байти або лише рядкові об’єкти. Результатом є об’єкт того самого типу, якщо повертається шлях або ім’я файлу.

Примітка

Оскільки різні операційні системи мають різні імена шляхів, у стандартній бібліотеці є кілька версій цього модуля. Модуль os.path завжди є модулем шляху, який підходить для операційної системи, у якій працює Python, і тому його можна використовувати для локальних шляхів. Однак ви також можете імпортувати та використовувати окремі модулі, якщо хочете маніпулювати шляхом, який завжди має один із різних форматів. Усі вони мають однаковий інтерфейс:

  • posixpath для шляхів у стилі UNIX

  • ntpath для шляхів Windows

Змінено в версії 3.8: exists(), lexists(), isdir(), isfile(), islink() і ismount() тепер замість цього повертають False створення винятку для шляхів, які містять символи або байти, які неможливо відобразити на рівні ОС.

os.path.abspath(path)

Повертає нормалізовану абсолютизовану версію імені шляху path. На більшості платформ це еквівалентно виклику функції normpath() таким чином: normpath(join(os.getcwd(), path)).

Змінено в версії 3.6: Приймає path-like object.

os.path.basename(path)

Повертає базову назву шляху path. Це другий елемент пари, що повертається шляхом передачі path до функції split(). Зверніть увагу, що результат цієї функції відрізняється від програми Unix basename; де basename для '/foo/bar/' повертає 'bar', функція basename() повертає порожній рядок ('').

Змінено в версії 3.6: Приймає path-like object.

os.path.commonpath(paths)

Return the longest common sub-path of each pathname in the sequence paths. Raise ValueError if paths contain both absolute and relative pathnames, the paths are on the different drives or if paths is empty. Unlike commonprefix(), this returns a valid path.

Availability: Unix, Windows.

Нове в версії 3.5.

Змінено в версії 3.6: Приймає послідовність шляхових об’єктів.

os.path.commonprefix(list)

Повертає найдовший префікс шляху (взятий посимвольно), який є префіксом усіх шляхів у списку. Якщо список порожній, поверніть порожній рядок ('').

Примітка

Ця функція може повертати недійсні шляхи, оскільки вона працює по символам за раз. Щоб отримати правильний шлях, перегляньте commonpath().

>>> os.path.commonprefix(['/usr/lib', '/usr/local/lib'])
'/usr/l'

>>> os.path.commonpath(['/usr/lib', '/usr/local/lib'])
'/usr'

Змінено в версії 3.6: Приймає path-like object.

os.path.dirname(path)

Повертає назву каталогу path. Це перший елемент пари, який повертається шляхом передачі шляху до функції split().

Змінено в версії 3.6: Приймає path-like object.

os.path.exists(path)

Повертає True, якщо path посилається на існуючий шлях або дескриптор відкритого файлу. Повертає False для пошкоджених символічних посилань. На деяких платформах ця функція може повертати False, якщо не надано дозвіл на виконання os.stat() над запитуваним файлом, навіть якщо шлях фізично існує.

Змінено в версії 3.3: шлях тепер може бути цілим числом: True повертається, якщо це дескриптор відкритого файлу, False інакше.

Змінено в версії 3.6: Приймає path-like object.

os.path.lexists(path)

Return True if path refers to an existing path. Returns True for broken symbolic links. Equivalent to exists() on platforms lacking os.lstat().

Змінено в версії 3.6: Приймає path-like object.

os.path.expanduser(path)

В Unix і Windows поверніть аргумент із початковим компонентом ~ або ~user, заміненим домашнім каталогом користувача.

В Unix початковий ~ замінюється змінною середовища HOME, якщо вона встановлена; інакше домашній каталог поточного користувача шукається в каталозі паролів за допомогою вбудованого модуля pwd. Початковий ~користувач шукається безпосередньо в каталозі паролів.

On Windows, USERPROFILE will be used if set, otherwise a combination of HOMEPATH and HOMEDRIVE will be used. An initial ~user is handled by stripping the last directory component from the created user path derived above.

Якщо розширення не вдається або якщо шлях не починається з тильди, шлях повертається без змін.

Змінено в версії 3.6: Приймає path-like object.

Змінено в версії 3.8: Більше не використовує HOME у Windows.

os.path.expandvars(path)

Повертає аргумент із розгорнутими змінними середовища. Підрядки у формі $name або ${name} замінюються значенням змінної середовища name. Неправильні назви змінних і посилання на неіснуючі змінні залишаються без змін.

У Windows підтримуються розширення %name% на додаток до $name і ${name}.

Змінено в версії 3.6: Приймає path-like object.

os.path.getatime(path)

Return the time of last access of path. The return value is a floating point number giving the number of seconds since the epoch (see the time module). Raise OSError if the file does not exist or is inaccessible.

os.path.getmtime(path)

Return the time of last modification of path. The return value is a floating point number giving the number of seconds since the epoch (see the time module). Raise OSError if the file does not exist or is inaccessible.

Змінено в версії 3.6: Приймає path-like object.

os.path.getctime(path)

Повертає системний час ctime, який у деяких системах (наприклад, Unix) є часом останньої зміни метаданих, а в інших (наприклад, Windows) є часом створення шляху. Поверненим значенням є число, що вказує кількість секунд з моменту епохи (див. модуль time). Викликати OSError, якщо файл не існує або недоступний.

Змінено в версії 3.6: Приймає path-like object.

os.path.getsize(path)

Повертає розмір у байтах шляху. Викликати OSError, якщо файл не існує або недоступний.

Змінено в версії 3.6: Приймає path-like object.

os.path.isabs(path)

Return True if path is an absolute pathname. On Unix, that means it begins with a slash, on Windows that it begins with a (back)slash after chopping off a potential drive letter.

Змінено в версії 3.6: Приймає path-like object.

os.path.isfile(path)

Повертає True, якщо path є існуючим звичайним файлом. Це йде за символічними посиланнями, тому і islink(), і isfile() можуть бути істинними для одного шляху.

Змінено в версії 3.6: Приймає path-like object.

os.path.isdir(path)

Повертає True, якщо path є існуючим каталогом. Це слідує за символічними посиланнями, тому і islink(), і isdir() можуть бути вірними для одного шляху.

Змінено в версії 3.6: Приймає path-like object.

Повертає True, якщо path посилається на існуючий запис каталогу, який є символічним посиланням. Завжди False, якщо символічні посилання не підтримуються середовищем виконання Python.

Змінено в версії 3.6: Приймає path-like object.

os.path.ismount(path)

Повертає True, якщо шлях path є mount point: точкою у файловій системі, де була змонтована інша файлова система. У POSIX функція перевіряє, чи батьківський елемент path, path/.., знаходиться на іншому пристрої, ніж path, або path/.. і шлях вказує на той самий i-node на тому самому пристрої — це має виявити точки монтування для всіх варіантів Unix і POSIX. Він не в змозі надійно виявити монтування прив’язки на тій же файловій системі. У Windows коренева буква диска та спільний UNC завжди є точками монтування, а для будь-якого іншого шляху викликається GetVolumePathName, щоб перевірити, чи відрізняється він від шляху введення.

Нове в версії 3.4: Support for detecting non-root mount points on Windows.

Змінено в версії 3.6: Приймає path-like object.

os.path.join(path, *paths)

Join one or more path components intelligently. The return value is the concatenation of path and any members of *paths with exactly one directory separator following each non-empty part except the last, meaning that the result will only end in a separator if the last part is empty. If a component is an absolute path, all previous components are thrown away and joining continues from the absolute path component.

On Windows, the drive letter is not reset when an absolute path component (e.g., r'\foo') is encountered. If a component contains a drive letter, all previous components are thrown away and the drive letter is reset. Note that since there is a current directory for each drive, os.path.join("c:", "foo") represents a path relative to the current directory on drive C: (c:foo), not c:\foo.

Змінено в версії 3.6: Приймає path-like object для path і paths.

os.path.normcase(path)

Нормалізуйте регістр імені шляху. У Windows перетворіть усі символи в імені шляху на малі літери, а також перетворіть косі риски на зворотні. В інших операційних системах повертайте шлях без змін.

Змінено в версії 3.6: Приймає path-like object.

os.path.normpath(path)

Нормалізуйте шлях шляхом згортання надлишкових роздільників і посилань верхнього рівня, щоб A//B, A/B/, A/./B і A/foo/.. /B всі стають A/B. Ця маніпуляція рядком може змінити значення шляху, який містить символічні посилання. У Windows він перетворює косі риски на зворотні. Щоб нормалізувати регістр, використовуйте normcase().

Примітка

On POSIX systems, in accordance with IEEE Std 1003.1 2013 Edition; 4.13 Pathname Resolution, if a pathname begins with exactly two slashes, the first component following the leading characters may be interpreted in an implementation-defined manner, although more than two leading characters shall be treated as a single character.

Змінено в версії 3.6: Приймає path-like object.

os.path.realpath(path, *, strict=False)

Return the canonical path of the specified filename, eliminating any symbolic links encountered in the path (if they are supported by the operating system).

By default, the path is evaluated up to the first component that does not exist, is a symlink loop, or whose evaluation raises OSError. All such components are appended unchanged to the existing part of the path.

Some errors that are handled this way include «access denied», «not a directory», or «bad argument to internal function». Thus, the resulting path may be missing or inaccessible, may still contain links or loops, and may traverse non-directories.

This behavior can be modified by keyword arguments:

If strict is True, the first error encountered when evaluating the path is re-raised. In particular, FileNotFoundError is raised if path does not exist, or another OSError if it is otherwise inaccessible.

If strict is os.path.ALLOW_MISSING, errors other than FileNotFoundError are re-raised (as with strict=True). Thus, the returned path will not contain any symbolic links, but the named file and some of its parent directories may be missing.

Примітка

Ця функція емулює процедуру операційної системи, щоб зробити шлях канонічним, який дещо відрізняється між Windows і UNIX стосовно того, як взаємодіють посилання та наступні компоненти шляху.

API операційної системи роблять шляхи канонічними за потреби, тому зазвичай не потрібно викликати цю функцію.

Змінено в версії 3.6: Приймає path-like object.

Змінено в версії 3.8: Символічні зв’язки та з’єднання тепер розпізнаються у Windows.

Змінено в версії 3.9.23: Додано параметр strict.

Змінено в версії 3.9.23 (unreleased): The ALLOW_MISSING value for the strict parameter was added.

os.path.ALLOW_MISSING

Special value used for the strict argument in realpath().

Нове в версії 3.9.23 (unreleased).

os.path.relpath(path, start=os.curdir)

Повертає відносний шлях до файлу до path або з поточного каталогу, або з додаткового каталогу start. Це обчислення шляху: доступ до файлової системи не здійснюється для підтвердження існування або природи шляху або початку. У Windows ValueError виникає, коли шлях і початок знаходяться на різних дисках.

start defaults to os.curdir.

Availability: Unix, Windows.

Змінено в версії 3.6: Приймає path-like object.

os.path.samefile(path1, path2)

Повертає True, якщо обидва аргументи шляху посилаються на той самий файл або каталог. Це визначається номером пристрою та номером i-вузла та викликає виняток, якщо виклик os.stat() будь-якого шляху не вдається.

Availability: Unix, Windows.

Змінено в версії 3.2: Додана підтримка Windows.

Змінено в версії 3.4: Windows тепер використовує ту саму реалізацію, що й усі інші платформи.

Змінено в версії 3.6: Приймає path-like object.

os.path.sameopenfile(fp1, fp2)

Повертає True, якщо файлові дескриптори fp1 і fp2 стосуються одного файлу.

Availability: Unix, Windows.

Змінено в версії 3.2: Додана підтримка Windows.

Змінено в версії 3.6: Приймає path-like object.

os.path.samestat(stat1, stat2)

Повертає True, якщо кортежі статистики stat1 і stat2 посилаються на той самий файл. Ці структури могли бути повернуті os.fstat(), os.lstat() або os.stat(). Ця функція реалізує основне порівняння, яке використовується samefile() і sameopenfile().

Availability: Unix, Windows.

Змінено в версії 3.4: Додана підтримка Windows.

Змінено в версії 3.6: Приймає path-like object.

os.path.split(path)

Розділіть шлях path на пару, (head, tail), де tail — це останній компонент шляху, а head — усе, що веде до нього. Частина хвоста ніколи не міститиме косу риску; якщо шлях закінчується скісною рискою, хвіст буде порожнім. Якщо в path немає скісної риски, head буде порожнім. Якщо шлях порожній, і голова, і хвіст порожні. Кінцеві похилі риски видаляються з голови, якщо це не корінь (лише одна або кілька похилих). У всіх випадках join(head, tail) повертає шлях до того самого місця, що й path (але рядки можуть відрізнятися). Також перегляньте функції dirname() і basename().

Змінено в версії 3.6: Приймає path-like object.

os.path.splitdrive(path)

Розділіть назву шляху path на пару (диск, хвіст), де диск є або точкою монтування, або порожнім рядком. У системах, які не використовують специфікації дисків, drive завжди буде порожнім рядком. У всіх випадках drive + tail буде таким самим, як path.

У Windows розділяє шлях на диск/загальну точку UNC і відносний шлях.

Якщо шлях містить букву диска, диск міститиме все, аж до двокрапки включно:

>>> splitdrive("c:/dir")
("c:", "/dir")

If the path contains a UNC path, drive will contain the host name and share, up to but not including the fourth separator:

>>> splitdrive("//host/computer/dir")
("//host/computer", "/dir")

Змінено в версії 3.6: Приймає path-like object.

os.path.splitext(path)

Розділіть назву шляху path на пару (root, ext) таким чином, root + ext == path, а розширення ext буде порожнім або починається з крапки та містить щонайбільше один період.

Якщо шлях не містить розширення, ext буде '':

>>> splitext('bar')
('bar', '')

Якщо шлях містить розширення, то ext буде встановлено для цього розширення, включаючи початкову точку. Зауважте, що попередні періоди ігноруватимуться:

>>> splitext('foo.bar.exe')
('foo.bar', '.exe')
>>> splitext('/foo/bar.exe')
('/foo/bar', '.exe')

Початкові періоди останнього компонента шляху вважаються частиною кореня:

>>> splitext('.cshrc')
('.cshrc', '')
>>> splitext('/foo/....jpg')
('/foo/....jpg', '')

Змінено в версії 3.6: Приймає path-like object.

os.path.supports_unicode_filenames

True, якщо довільні рядки Unicode можуть використовуватися як імена файлів (в межах обмежень, накладених файловою системою).