glob
— Unix style pathname pattern expansion¶
Вихідний код: Lib/glob.py
Модуль glob
знаходить усі імена шляхів, що відповідають заданому шаблону, згідно з правилами, що використовуються оболонкою Unix, хоча результати повертаються в довільному порядку. Розгортання тильди не виконується, але *
, ?
і діапазони символів, виражені []
, будуть правильно зіставлені. Це робиться за допомогою спільного використання функцій os.scandir()
і fnmatch.fnmatch()
, а не шляхом фактичного виклику підоболонки.
Зауважте, що файли, які починаються з крапки (.
), можуть бути зіставлені лише шаблонами, які також починаються з крапки, на відміну від fnmatch.fnmatch()
або pathlib.Path.glob()
. (Для розширення змінної тильди та оболонки використовуйте os.path.expanduser()
і os.path.expandvars()
.)
Для буквального збігу заберіть метасимволи в дужки. Наприклад, ''[?]'
відповідає символу ''?'
.
The glob
module defines the following functions:
- glob.glob(pathname, *, root_dir=None, dir_fd=None, recursive=False, include_hidden=False)¶
Return a possibly empty list of path names that match pathname, which must be a string containing a path specification. pathname can be either absolute (like
/usr/src/Python-1.5/Makefile
) or relative (like../../Tools/*/*.gif
), and can contain shell-style wildcards. Broken symlinks are included in the results (as in the shell). Whether or not the results are sorted depends on the file system. If a file that satisfies conditions is removed or added during the call of this function, whether a path name for that file will be included is unspecified.Якщо root_dir не
None
, це має бути path-like object, що вказує кореневий каталог для пошуку. Це має такий самий вплив наglob()
, як і зміна поточного каталогу перед його викликом. Якщо pathname є відносним, результат міститиме шляхи відносно root_dir.Ця функція може підтримувати шляхи відносно дескрипторів каталогу з параметром dir_fd.
Якщо recursive має значення true, шаблон «
**
» відповідатиме будь-яким файлам і нулю або більше каталогів, підкаталогів і символічних посилань на каталоги. Якщо за шаблоном йдеos.sep
абоos.altsep
, файли не збігатимуться.If include_hidden is true, «
**
» pattern will match hidden directories.Викликає подію аудиту
glob.glob
з аргументамиpathname
,recursive
.Викликає подію аудиту
glob.glob/2
з аргументамиpathname
,recursive
,root_dir
,dir_fd
.Примітка
Використання шаблону «
**
» у великих деревах каталогів може зайняти надто багато часу.Примітка
This function may return duplicate path names if pathname contains multiple «
**
» patterns and recursive is true.Змінено в версії 3.5: Підтримка рекурсивних глобусів з використанням «
**
».Змінено в версії 3.10: Додано параметри root_dir і dir_fd.
Змінено в версії 3.11: Added the include_hidden parameter.
- glob.iglob(pathname, *, root_dir=None, dir_fd=None, recursive=False, include_hidden=False)¶
Повертає iterator, який дає ті самі значення, що й
glob()
, фактично не зберігаючи їх усі одночасно.Викликає подію аудиту
glob.glob
з аргументамиpathname
,recursive
.Викликає подію аудиту
glob.glob/2
з аргументамиpathname
,recursive
,root_dir
,dir_fd
.Примітка
This function may return duplicate path names if pathname contains multiple «
**
» patterns and recursive is true.Змінено в версії 3.5: Підтримка рекурсивних глобусів з використанням «
**
».Змінено в версії 3.10: Додано параметри root_dir і dir_fd.
Змінено в версії 3.11: Added the include_hidden parameter.
- glob.escape(pathname)¶
Екранування всіх спеціальних символів (
'?'
,'*'
і'['
). Це корисно, якщо ви хочете зіставити довільний літеральний рядок, який може містити спеціальні символи. Спеціальні символи в точках доступу/UNC не екрануються, напр. у Windowsescape('//?/c:/Quo vadis?.txt')
повертає'//?/c:/Quo vadis[?].txt''
.Added in version 3.4.
- glob.translate(pathname, *, recursive=False, include_hidden=False, seps=None)¶
Convert the given path specification to a regular expression for use with
re.match()
. The path specification can contain shell-style wildcards.Наприклад:
>>> import glob, re >>> >>> regex = glob.translate('**/*.txt', recursive=True, include_hidden=True) >>> regex '(?s:(?:.+/)?[^/]*\\.txt)\\Z' >>> reobj = re.compile(regex) >>> reobj.match('foo/bar/baz.txt') <re.Match object; span=(0, 15), match='foo/bar/baz.txt'>
Path separators and segments are meaningful to this function, unlike
fnmatch.translate()
. By default wildcards do not match path separators, and*
pattern segments match precisely one path segment.If recursive is true, the pattern segment «
**
» will match any number of path segments.If include_hidden is true, wildcards can match path segments that start with a dot (
.
).A sequence of path separators may be supplied to the seps argument. If not given,
os.sep
andaltsep
(if available) are used.Дивись також
pathlib.PurePath.full_match()
andpathlib.Path.glob()
methods, which call this function to implement pattern matching and globbing.Added in version 3.13.
Приклади¶
Consider a directory containing the following files:
1.gif
, 2.txt
, card.gif
and a subdirectory sub
which contains only the file 3.txt
. glob()
will produce
the following results. Notice how any leading components of the path are
preserved.
>>> import glob
>>> glob.glob('./[0-9].*')
['./1.gif', './2.txt']
>>> glob.glob('*.gif')
['1.gif', 'card.gif']
>>> glob.glob('?.gif')
['1.gif']
>>> glob.glob('**/*.txt', recursive=True)
['2.txt', 'sub/3.txt']
>>> glob.glob('./**/', recursive=True)
['./', './sub/']
Якщо каталог містить файли, які починаються з .
, вони не будуть зіставлені за умовчанням. Наприклад, розглянемо каталог, що містить card.gif
і .card.gif
:
>>> import glob
>>> glob.glob('*.gif')
['card.gif']
>>> glob.glob('.c*')
['.card.gif']
Дивись також
The fnmatch
module offers shell-style filename (not path) expansion.
Дивись також
Модуль pathlib
пропонує об’єкти шляху високого рівня.