9

Pythonで.gitignoreスタイルのfnmatch()を使用する最も簡単な方法は何でしょうか。stdlibは、パス仕様をUNIXスタイルのパス正規表現と照合するmatch()関数を提供していないようです。

.gitignoreには、(ブラック)リストされるワイルドカードを含むパスとファイルの両方があります

4

2 に答える 2

21

;のようなものを含む完全な仕様を実装するpathspecと呼ばれるライブラリがあります。ドキュメントには、 Gitパターンマッチングの処理方法が説明されています(コードも表示されます)。.gitignore**/*.py

>>> import pathspec
>>> spec_src = '**/*.pyc'
>>> spec = pathspec.PathSpec.from_lines(pathspec.patterns.GitWildMatchPattern, spec_src.splitlines())
>>> set(spec.match_files({"test.py", "test.pyc", "deeper/file.pyc", "even/deeper/file.pyc"}))
set(['test.pyc', 'even/deeper/file.pyc', 'deeper/file.pyc'])
>>> set(spec.match_tree("pathspec/"))
set(['__init__.pyc', 'gitignore.pyc', 'util.pyc', 'pattern.pyc', 'tests/__init__.pyc', 'tests/test_gitignore.pyc', 'compat.pyc', 'pathspec.pyc'])
于 2014-02-28T09:05:46.100 に答える
9

.gitignoreの例にリストされているような混合UNIXワイルドカードパターンを使用する場合は、各パターンを取得してで使用fnmatch.translateしないのはなぜre.searchですか?

import fnmatch
import re

s = '/path/eggs/foo/bar'
pattern = "eggs/*"

re.search(fnmatch.translate(pattern), s)
# <_sre.SRE_Match object at 0x10049e988>

translateワイルドカードパターンをreパターンに変換します

隠しUNIXファイル:

s = '/path/to/hidden/.file'
isHiddenFile = re.search(fnmatch.translate('.*'), s)
if not isHiddenFile:
    # do something with it
于 2012-04-06T20:22:56.907 に答える