私はこのパターンを持っていて、このwindowsのファイル名と一致させたいと思います。無実を保護するために名前が変更されました:[a-zA-Z] +はアルファベットの連続する文字に置き換えられました。PythonのRegexpは、バックスラッシュで失われています。
pattern = "C:\\\\a\\\\b\\\\c\\\\d\\\\e f\\\\(g|h|i)\\\\j k\\\\l\\\\m\\\\(n\\\\(o|p)|q)\\\\.*\.sql)"
str = "C:\\a\\b\\c\\d\\e f\\h\\j k\\l\\m\\n\\o\\z_zz.function.sql"
しかし、pythonは、比類のないparenについて不平を言っています。どうしてか分かりません。それが私に与えているポジション(62)も、私の括約書と一線を画していませんが、私が推測しなければならないことは、たくさんのバックスラッシュのどれかが誤ってエスケープしていると言うことです。 。。に、しかし、助けていないものを目の前に多くのバックスラッシュを追加するあなたのバックスラッシュはすべて適切にエスケープされている
ヒント:必要なバックスラッシュの数を減らすために、 "生の"文字列記法を使用することができます。例えば。 'r'C:\ a \ b'' ==' C:\\ a \\ b'' – Billy
リテラルのバックスラッシュを処理する必要がある場合は、生の文字列リテラルを使用します。 –
私はもともと、s、d、wで始まるパスから生じる混乱のためにそれを避けました... –