10.7. Glob - Unix Style Pathname Pattern Expansion - Python 2.7.18 Documentation
10.7. Glob - Unix Style Pathname Pattern Expansion - Python 2.7.18 Documentation
18 documentation
This document is for an old version of Python that is no longer supported. You should upgrade and
read the Python documentation for the current stable release.
The glob module finds all the pathnames matching a specified pattern according to the rules used
by the Unix shell, although results are returned in arbitrary order. No tilde expansion is done, but * ,
? , and character ranges expressed with [] will be correctly matched. This is done by using the
os.listdir() and fnmatch.fnmatch() functions in concert, and not by actually invoking a subshell.
Note that unlike fnmatch.fnmatch() , glob treats filenames beginning with a dot ( . ) as special cases.
(For tilde and shell variable expansion, use os.path.expanduser() and os.path.expandvars() .)
For a literal match, wrap the meta-characters in brackets. For example, '[?]' matches the
character '?' .
For example, consider a directory containing only the following files: 1.gif , 2.txt , and card.gif .
glob() will produce the following results. Notice how any leading components of the path are
preserved.
If the directory contains files starting with . they won’t be matched by default. For example,
consider a directory containing card.gif and .card.gif :
https://docs.python.org/2/library/glob.html?highlight=glob#module-glob 1/2
5/2/2020 10.7. glob — Unix style pathname pattern expansion — Python 2.7.18 documentation
>>> glob.glob('.c*')
['.card.gif']
See also:
Module fnmatch
Shell-style filename (not path) expansion
https://docs.python.org/2/library/glob.html?highlight=glob#module-glob 2/2