mirror of
https://github.com/python/cpython.git
synced 2024-11-24 17:47:13 +01:00
108 lines
3.5 KiB
ReStructuredText
108 lines
3.5 KiB
ReStructuredText
:mod:`!fnmatch` --- Unix filename pattern matching
|
|
==================================================
|
|
|
|
.. module:: fnmatch
|
|
:synopsis: Unix shell style filename pattern matching.
|
|
|
|
**Source code:** :source:`Lib/fnmatch.py`
|
|
|
|
.. index:: single: filenames; wildcard expansion
|
|
|
|
.. index:: pair: module; re
|
|
|
|
--------------
|
|
|
|
This module provides support for Unix shell-style wildcards, which are *not* the
|
|
same as regular expressions (which are documented in the :mod:`re` module). The
|
|
special characters used in shell-style wildcards are:
|
|
|
|
.. index::
|
|
single: * (asterisk); in glob-style wildcards
|
|
single: ? (question mark); in glob-style wildcards
|
|
single: [] (square brackets); in glob-style wildcards
|
|
single: ! (exclamation); in glob-style wildcards
|
|
single: - (minus); in glob-style wildcards
|
|
|
|
+------------+------------------------------------+
|
|
| Pattern | Meaning |
|
|
+============+====================================+
|
|
| ``*`` | matches everything |
|
|
+------------+------------------------------------+
|
|
| ``?`` | matches any single character |
|
|
+------------+------------------------------------+
|
|
| ``[seq]`` | matches any character in *seq* |
|
|
+------------+------------------------------------+
|
|
| ``[!seq]`` | matches any character not in *seq* |
|
|
+------------+------------------------------------+
|
|
|
|
For a literal match, wrap the meta-characters in brackets.
|
|
For example, ``'[?]'`` matches the character ``'?'``.
|
|
|
|
.. index:: pair: module; glob
|
|
|
|
Note that the filename separator (``'/'`` on Unix) is *not* special to this
|
|
module. See module :mod:`glob` for pathname expansion (:mod:`glob` uses
|
|
:func:`.filter` to match pathname segments). Similarly, filenames starting with
|
|
a period are not special for this module, and are matched by the ``*`` and ``?``
|
|
patterns.
|
|
|
|
Also note that :func:`functools.lru_cache` with the *maxsize* of 32768 is used to
|
|
cache the compiled regex patterns in the following functions: :func:`fnmatch`,
|
|
:func:`fnmatchcase`, :func:`.filter`.
|
|
|
|
.. function:: fnmatch(name, pat)
|
|
|
|
Test whether the filename string *name* matches the pattern string *pat*,
|
|
returning ``True`` or ``False``. Both parameters are case-normalized
|
|
using :func:`os.path.normcase`. :func:`fnmatchcase` can be used to perform a
|
|
case-sensitive comparison, regardless of whether that's standard for the
|
|
operating system.
|
|
|
|
This example will print all file names in the current directory with the
|
|
extension ``.txt``::
|
|
|
|
import fnmatch
|
|
import os
|
|
|
|
for file in os.listdir('.'):
|
|
if fnmatch.fnmatch(file, '*.txt'):
|
|
print(file)
|
|
|
|
|
|
.. function:: fnmatchcase(name, pat)
|
|
|
|
Test whether the filename string *name* matches the pattern string *pat*,
|
|
returning ``True`` or ``False``;
|
|
the comparison is case-sensitive and does not apply :func:`os.path.normcase`.
|
|
|
|
|
|
.. function:: filter(names, pat)
|
|
|
|
Construct a list from those elements of the :term:`iterable` *names*
|
|
that match pattern *pat*.
|
|
It is the same as ``[n for n in names if fnmatch(n, pat)]``,
|
|
but implemented more efficiently.
|
|
|
|
|
|
.. function:: translate(pat)
|
|
|
|
Return the shell-style pattern *pat* converted to a regular expression for
|
|
using with :func:`re.match`.
|
|
|
|
Example:
|
|
|
|
>>> import fnmatch, re
|
|
>>>
|
|
>>> regex = fnmatch.translate('*.txt')
|
|
>>> regex
|
|
'(?s:.*\\.txt)\\Z'
|
|
>>> reobj = re.compile(regex)
|
|
>>> reobj.match('foobar.txt')
|
|
<re.Match object; span=(0, 10), match='foobar.txt'>
|
|
|
|
|
|
.. seealso::
|
|
|
|
Module :mod:`glob`
|
|
Unix shell-style path expansion.
|