"glob" --- Ekspansi pola nama jalur bergaya Unix
************************************************

**Kode sumber:** Lib/glob.py

======================================================================

Modul "glob" menemukan semua nama lokasi yang cocok dengan pola yang
ditentukan sesuai dengan aturan yang digunakan oleh shell Unix,
meskipun hasilnya dikembalikan dalam urutan arbitrer. Tidak ada
ekspansi tilde yang dilakukan, tetapi "*", "?", Dan rentang karakter
yang diekspresikan dengan "[]" akan dicocokkan dengan benar. Ini
dilakukan dengan menggunakan fungsi "os.scandir()" dan
"fnmatch.fnmatch()" secara bersamaan, dan bukan dengan benar-benar
memanggil subshell. Perhatikan bahwa tidak seperti
"fnmatch.fnmatch()", "glob" memperlakukan nama file yang dimulai
dengan titik (".") sebagai kasus khusus. (Untuk ekspansi variabel
tilde dan shell, gunakan "os.path.expanduser()" dan
"os.path.expandvars()".)

Untuk mencocokan literal, bungkus karakter meta dalam tanda kurung.
Misalnya, "'[?]'" cocok dengan karakter "'?'".

Lihat juga: Modul "pathlib" menawarkan objek jalur tingkat tinggi.

glob.glob(pathname, *, recursive=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).

   Jika *rekursif* benar, pola ""**"" akan cocok dengan semua file dan
   nol atau lebih direktori, subdirektori, dan tautan simbolis ke
   direktori. Jika pola diikuti oleh "os.sep" atau "os.altsep" maka
   file tidak akan cocok.

   Catatan:

     Menggunakan pola ""**"" di pohon direktori yang besar dapat
     menghabiskan banyak waktu.

   Berubah pada versi 3.5: Dukungan untuk glob rekursif menggunakan
   ""**"".

glob.iglob(pathname, *, recursive=False)

   Mengembalikan sebuah *iterator* yang menghasilkan nilai yang sama
   dengan "glob()" tanpa benar-benar menyimpan semuanya secara
   bersamaan.

glob.escape(pathname)

   Escape semua karakter khusus ("'?'", "'*'" dan "'['"). Ini berguna
   jika Anda ingin mencocokkan string literal arbitrer yang mungkin
   memiliki karakter khusus di dalamnya. Karakter khusus dalam
   drive/titik berbagi UNC tidak di-escape, mis. pada Windows
   "escape('//?/c:/Quo vadis?.txt')" mengembalikan "'//?/c:/Quo
   vadis[?].txt'".

   Baru pada versi 3.4.

Misalnya, pertimbangkan direktori yang berisi file-file berikut:
"1.gif", "2.txt", "card.gif" dan subdirektori "sub" yang hanya berisi
file :file: *3.txt*. "glob()" akan memberikan hasil sebagai berikut.
Perhatikan bagaimana komponen utama jalur dipertahankan.

   >>> 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/']

Jika direktori berisi file yang dimulai dengan "." mereka tidak akan
dicocokkan secara default. Misalnya, pertimbangkan direktori yang
berisi "card.gif" dan ".card.gif"

   >>> import glob
   >>> glob.glob('*.gif')
   ['card.gif']
   >>> glob.glob('.c*')
   ['.card.gif']

Lihat juga:

  Modul "fnmatch"
     Ekspansi nama file bergaya shell (bukan jalur)
