PyCharm 2026.1 Help

構造検索と置換の例

ご存知のとおり、通常の検索と構造検索の主な違いは、構造検索ではプログラミング言語の構造テンプレートを探すことです。

構造検索の良いところは、既存のテンプレートを基にパターンを作成でき、コードの検索や置換時に時間を節約できる点です。

既存のテンプレートの豊富なリストは、単純なパターンから複雑なパターンまで、多くのユースケースをカバーしています。

パターン内の各項目は、両側に $ 記号が付いた変数で構成されます。

HTML と XML の例

次の例は、HTML および XML コードで構造検索を使用する方法を示しています。

XML および HTML タグ、属性、それらの値の検索

タグを検索する最も簡単なテンプレートは <$tag$/> です。

  1. 変数 $tag$ に制約を設定することにより、検索するタグを指定できます。 例: li を指定すると、すべての li タグが取得されます。

  2. 次の XML および HTML での検索テンプレートを考えてみてください: <$tag$ $attribute$=$value$ />。 例えば、 $attribute$ 変数に id テキストフィルターを指定し、 $value$ 変数に \d+ 正規表現をテキストフィルターとして指定すると、 id 属性に数値を持つすべてのタグを見つけることができます。

    数値 ID を持つ li タグの検索

id 属性が 2 より大きい行をすべて削除する

  1. HTML ファイルを作成し、次のコードを貼り付けてください:

    <!doctype html> <html> <head> <title>Structural Search Example</title> <body> <ul> <li id="1">Example line 1</li> <li id="2">Example line 2</li> <li id="3">Example line 3</li> <li id="a">Example line a</li> <li id="5">Example line 5</li> </ul> </body> </html>
  2. メインメニューで 編集 | 検索 | 構造検索 へ移動します。

  3. 言語 リストから HTML ファイルの操作 を選択してください。

  4. 次の文字列を 検索テンプレート フィールドに貼り付けます。

    <$tag$ $attribute$="$value$">
  5. $tag$ 変数をクリックします。

  6. フィルターパネルで、 Add modifier をクリックし、 テキスト を選択して、値フィールドに li と入力します。

    フィルターパネルが表示されていない場合は、 Toggle Modifier Panel をクリックします。

    フィルターパネルを切り替える
  7. $attribute$ 変数をクリックします。

  8. フィルターパネルで、 Add modifier をクリックし、 テキスト を選択して、値フィールドに id と入力します。

  9. $value$ 変数をクリックします。

  10. フィルターパネルで、 Add modifier をクリックし、 テキスト を選択して、値フィールドに \d+ と入力します。

    \d+ 正規表現は、検索結果を数値に制限します。 そのため、 id="a" のある行は除外されます。

  11. フィルターパネルからフォーカスを切り替えずに、 追加 ボタンをクリックし、 スクリプト を選択して、次のコードを貼り付けます。

    value.getText().replaceAll (/"/, '').toInteger() > 2

    スクリプトは $value$ 変数の内容を読み取り、それを文字列として返します(たとえば、 "1")。 次に、スクリプトはすべての引用符を置き換え、文字列値を整数に変換して、 2 と比較します。

    2 より大きい ID を持つ行を削除する

li タグのクラス属性の大文字の値を小文字に変換する

  1. HTML ファイルを作成し、次のコードを貼り付けてください:

    <!doctype html> <html> <head> <title class="EXAMPLE">Structural Replace Example</title> <body> <ul> <li class="EXAMPLE">Example line 1</li> <li class="example">Example line 2</li> <li class="EXAMPLE">Example line 3</li> <li class="example">Example line a</li> <li id="EXAMPLE">Example line 5</li> </ul> </body> </html>
  2. メインメニューで 編集 | 検索 | 構造置換 へ移動します。

  3. 言語 リストから HTML ファイルの操作 を選択してください。

  4. 次の文字列を 検索テンプレート フィールドに貼り付けます。

    <$tag$ $attribute$="$value$">
  5. 大/小文字を区別する チェックボックスを選択します。

  6. $tag$ 変数をクリックします。

  7. フィルターパネルで、 Add modifier をクリックし、 テキスト を選択して、値フィールドに li と入力します。

  8. $attribute$ 変数をクリックします。

  9. フィルターパネルで、 Add modifier をクリックし、 テキスト を選択して、値フィールドに class と入力します。

  10. $value$ 変数をクリックします。

  11. フィルターパネルで、 Add modifier をクリックし、 テキスト を選択して、値フィールドに [A-Z].* と入力します。

    [A-Z].* 正規表現は、検索結果を大文字に制限します。

  12. ターゲット リストから を選択してください。 この手順では、 class 属性のすべての大文字の値をハイライトします。

  13. テンプレートを置換 フィールドに、 $to_lower_case$ 変数を貼り付けます。

  14. $to_lower_case$ 変数をクリックします。

  15. フィルターパネルで、 Add modifier をクリックし、 スクリプト を選択して、次のコードを貼り付けます。

    value.getText().toLowerCase()
    ターゲットを構造的に置き換える
  16. 検索 をクリックしてください。

  17. 検索 ツールウィンドウで、検索結果をプレビューし、 すべて置換 をクリックします。

    find.replace.all.action
2026 年 6 月 1 日