{"meta":{"title":"GitHub Copilot を使用したコードのリファクタリング","intro":"Copilot 人工知能を活用して、コードをすばやく効果的にリファクタリングできます。","product":"GitHub Copilot","breadcrumbs":[{"href":"/ja/copilot","title":"GitHub Copilot"},{"href":"/ja/copilot/tutorials","title":"チュートリアル"},{"href":"/ja/copilot/tutorials/refactor-code","title":"コードのリファクタリング"}],"documentType":"article"},"body":"# GitHub Copilot を使用したコードのリファクタリング\n\nCopilot 人工知能を活用して、コードをすばやく効果的にリファクタリングできます。\n\n## 概要\n\nコードのリファクタリングとは、既存のコードの動作を変更することなく再構築するプロセスです。 リファクタリングの利点には、コードの読みやすさを向上させ、複雑さを軽減し、コードを保守しやすくし、新機能を簡単に追加できるようにする点などが含まれます。\n\nこの記事では、Copilot を使用して IDE でコードをリファクタリングする方法について説明します。\n\n> \\[!NOTE] 応答の例は、この記事に含まれています。 ギットハブ コパイロット チャット では、ここに示したものと異なる応答が返される場合があります。\n\n## コードの解釈\n\n既存のコードを変更する前に、その目的と現在どのように動作しているかを理解しておく必要があります。 Copilot は、次のことができるようにします:\n\n1. IDE のエディターで関連するコードを選択します。\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n3. インライン チャットの入力ボックスに、スラッシュ (`/`) を入力します。\n4. ドロップダウン リストで **\\[/explain]** を選択し、<kbd>Enter</kbd> キーを押します。\n5. Copilot が返す説明が数行を超える場合、**チャットで表示** をクリックすると、説明が読みやすくなります。\n\n## 非効率的なコードの最適化\n\nCopilot は、コードを最適化するのに役立ちます。例えば、コードをより短時間で実行できます。\n\n### コード例\n\n以下の 2 つのセクションでは、次の Bash スクリプトの例を使用して、非効率的なコードを最適化する方法を示します:\n\n```bash\n#!/bin/bash\n\n# Find all .txt files and count lines in each\nfor file in $(find . -type f -name \"*.txt\"); do\n    wc -l \"$file\"\ndone\n```\n\n### コパイロットチャット を使用する\n\nCopilot は、Bash スクリプトの例のようにコードを最適化できるかどうかを示します。\n\n1. ```\n          `for` loopまたはファイルの内容全体を選択します。\n   ```\n\n2. アクティビティ バーのチャット アイコンをクリックするか、キーボード ショートカットを使用して、コパイロットチャット を開きます。\n\n   * **VS Code および Visual Studio:**<kbd>Control</kbd>+<kbd>Command</kbd>+<kbd>i</kbd> (Mac) / <kbd>Ctrl</kbd>+<kbd>Alt</kbd>+<kbd>i</kbd> (Windows/Linux)\n   * **JetBrains:**<kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>c</kbd>\n\n3. チャット パネルの下部にある入力ボックスに、次のように入力します: `Can this script be improved?`\n\n   Copilot は、コードをより効率的にする提案で応答します。\n\n4. 推奨される変更を適用するには:\n\n   * **VS Code と JetBrains では:** チャット パネルで提案にカーソルを合わせ、**カーソル位置で挿入** アイコンをクリックします。\n\n     ![コパイロットチャット パネルにある \\[カーソル位置で挿入\\] アイコンのスクリーンショット。](/assets/images/help/copilot/insert-at-cursor.png)\n\n   * \\*\\*Visual Studio では:\\*\\***プレビュー** をクリックし、比較ビューで **承諾** をクリックします。\n\n### Copilot インライン チャットを使用する\n\nまたは、Bash スクリプトの例のような既存のコードが非効率的であることが既にわかっている場合は、次のようにします:\n\n1. ```\n          `for` loopまたはファイルの内容全体を選択します。\n   ```\n\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n\n3. 「`optimize`」と入力して <kbd>Enter</kbd> キーを押します。\n\n   Copilot は、修正されたコードを提案します。 次に例を示します。\n\n   ```bash\n   find . -type f -name \"*.txt\" -exec wc -l {} +\n   ```\n\n   これは、この記事で前に示した元のコードよりも効率的です。なぜなら、`-exec ... +` を使用すれば、`find` は検出された `wc` ファイルごとに `wc` を 1 回呼び出すのではなく、使用して複数のファイルを一度に `*.txt` に渡すことができるためです。\n\n4. Copilot の提案を評価し、変更に同意する場合は、次の手順を実行します:\n\n   * **VS Code および Visual Studio では:** **\\[承諾]** をクリックします。\n   * **JetBrains**: プレビュー アイコン (二重矢印) をクリックし、\\[すべての差分の適用] アイコン (二重山かっこ) をクリックします。\n\nすべての Copilot の提案と同様に、修正されたコードがエラーなしで実行され、正しい結果が生成されることを常に確認する必要があります。\n\n## 繰り返しコードをクリーンアップする\n\n繰り返しを回避すると、コードの修正とデバッグが容易になります。 たとえば、同じ計算がファイル内の異なる場所で複数回実行される場合は、その計算を関数に移動できます。\n\n次の非常に単純な JavaScript の例では、同じ計算 (商品価格に販売数を掛けたもの) が 2 か所で実行されます。\n\n```javascript\nlet totalSales = 0;\n\nlet applePrice = 3;\nlet applesSold = 100;\ntotalSales += applePrice * applesSold;\n\nlet orangePrice = 5;\nlet orangesSold = 50;\ntotalSales += orangePrice * orangesSold;\n\nconsole.log(`Total: ${totalSales}`);\n```\n\nCopilot に、繰り返し計算を関数に移動するように依頼できます。\n\n1. ファイルのコンテンツ全体を選択します。\n\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n\n3. 「`move repeated calculations into functions`」と入力して <kbd>Enter</kbd> キーを押します。\n\n   Copilot は、修正されたコードを提案します。 次に例を示します。\n\n   ```javascript\n   function calculateSales(price, quantity) {\n     return price * quantity;\n   }\n\n   let totalSales = 0;\n\n   let applePrice = 3;\n   let applesSold = 100;\n   totalSales += calculateSales(applePrice, applesSold);\n\n   let orangePrice = 5;\n   let orangesSold = 50;\n   totalSales += calculateSales(orangePrice, orangesSold);\n\n   console.log(`Total: ${totalSales}`);\n   ```\n\n4. Copilot の提案を評価し、変更に同意する場合は、次の手順を実行します:\n\n   * **VS Code および Visual Studio では:** **\\[承諾]** をクリックします。\n   * **JetBrains**: プレビュー アイコン (二重矢印) をクリックし、\\[すべての差分の適用] アイコン (二重山かっこ) をクリックします。\n\nすべての Copilot の提案と同様に、修正されたコードがエラーなしで実行され、正しい結果が生成されることを常に確認する必要があります。\n\n## コードの簡潔化\n\nコードが不必要に冗長な場合、読み取りと保守が困難になる可能性があります。 Copilot は、選択したコードの簡潔化されたバージョンを提案できます。\n\n次の例では、この Python コードは四角形と円の領域を出力しますが、より簡潔に記述できます:\n\n```python\ndef calculate_area_of_rectangle(length, width):\n    area = length * width\n    return area\n\ndef calculate_area_of_circle(radius):\n    import math\n    area = math.pi * (radius ** 2)\n    return area\n\nlength_of_rectangle = 10\nwidth_of_rectangle = 5\narea_of_rectangle = calculate_area_of_rectangle(length_of_rectangle, width_of_rectangle)\nprint(f\"Area of rectangle: {area_of_rectangle}\")\n\nradius_of_circle = 7\narea_of_circle = calculate_area_of_circle(radius_of_circle)\nprint(f\"Area of circle: {area_of_circle}\")\n```\n\n1. ファイルのコンテンツ全体を選択します。\n\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n\n3. 「`make this more concise`」と入力して <kbd>Enter</kbd> キーを押します。\n\n   Copilot は、修正されたコードを提案します。 次に例を示します。\n\n   ```python\n   import math\n\n   def calculate_area_of_rectangle(length, width):\n     return length * width\n\n   def calculate_area_of_circle(radius):\n     return math.pi * (radius ** 2)\n\n   print(f\"Area of rectangle: {calculate_area_of_rectangle(10, 5)}\")\n   print(f\"Area of circle: {calculate_area_of_circle(7)}\")\n   ```\n\n4. Copilot の提案を評価し、変更に同意する場合は、次の手順を実行します:\n\n   * **VS Code および Visual Studio では:** **\\[承諾]** をクリックします。\n   * **JetBrains**: プレビュー アイコン (二重矢印) をクリックし、\\[すべての差分の適用] アイコン (二重山かっこ) をクリックします。\n\nすべての Copilot の提案と同様に、修正されたコードがエラーなしで実行され、正しい結果が生成されることを常に確認する必要があります。\n\n## 複雑なコード単位の分割\n\n複数の操作を実行する大規模なメソッドまたは関数は、特定の操作の実行に重点を置いた小さく単純な関数よりも、再利用の機会が少なくなる可能性があります。 また、解釈とデバッグが難しくなる場合もあります。\n\nCopilot を使用すると、複雑なコードのブロックを、再利用に適した小さな単位に分割するのに役立ちます。\n\n次の Python コードは非常に単純な例ですが、単一の関数を特定の操作を実行する 2 つの関数に分割する原則を示しています。\n\n```python\nimport pandas as pd\nfrom pandas.io.formats.style import Styler\n\ndef process_data(item, price):\n    # Cleanse data\n    item = item.strip()  # Strip whitespace from item\n    price = price.strip()  # Strip whitespace from price\n    price = float(price) # Convert price to a float\n    # More cleansing operations here\n\n    # Create and print a DataFrame\n    data = {'Item': [item], 'Price': [price]}\n    df = pd.DataFrame(data)\n    print(df.to_string(index=False))\n\n# Example usage\nitem = \"   Apple \"\nprice = \" 1.25\"\nprocess_data(item, price)\n```\n\n```\n          `process_data` 関数を分割するには:\n```\n\n1. 関数名にカーソルを置きます。\n\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n\n3. 「`split into 2 separate functions: one for cleansing data, the other for printing`」と入力して <kbd>Enter</kbd> キーを押します。\n\n   Copilot は、修正されたコードを提案します。 次に例を示します。\n\n   ```python\n   def cleanse_data(item, price):\n     # Cleanse data\n     item = item.strip()  # Strip whitespace from item\n     price = price.strip()  # Strip whitespace from price\n     price = float(price)  # Convert price to a float\n     return item, price\n\n   def print_data(item, price):\n     # Create and print a DataFrame\n     data = {'Item': [item], 'Price': [price]}\n     df = pd.DataFrame(data)\n     print(df.to_string(index=False))\n\n   def process_data(item, price):\n     item, price = cleanse_data(item, price)\n     print_data(item, price)\n   ```\n\n   > \\[!NOTE] 上記の提案例では、既存の関数を 3 つの関数に置き換えています。 3 番目の関数は、他の 2 つの関数を呼び出すだけで、`process_data` 関数を呼び出す既存のコードを使用できます。\n\n4. Copilot の提案を評価し、変更に同意する場合は、次の手順を実行します:\n\n   * **VS Code および Visual Studio では:** **\\[承諾]** をクリックします。\n   * **JetBrains**: プレビュー アイコン (二重矢印) をクリックし、\\[すべての差分の適用] アイコン (二重山かっこ) をクリックします。\n\nすべての Copilot の提案と同様に、修正されたコードがエラーなしで実行され、正しい結果が生成されることを常に確認する必要があります。\n\n## 読みやすくするために条件付きコードを書き換える\n\n多くの場合、いくつかの方法で、さまざまな条件に応じて実行される、または実行されないコードを記述することができます。 特定のユースケースでは他より適している条件構造があり、別の条件構造を選択すると、コードがより読みやすくなる場合があります。\n\nこの Java メソッドでは、一連の `if` ステートメントと `else if` ステートメントを使用して、実行する操作を決定します:\n\n```java\npublic String getSound(String animal) {\n  if (animal == null) {\n      System.out.println(\"Oops! A null animal?\");\n  } else if (animal.equalsIgnoreCase(\"Dog\")) {\n      return \"Bark\";\n  } else if ( animal.equalsIgnoreCase(\"Cat\")) {\n      return \"Meow\";\n  } else if ( animal.equalsIgnoreCase(\"Bird\")) {\n      return \"Tweet\";\n  }\n  return \"Unknown\";\n}\n```\n\n```\n          `switch` ステートメントは、同じロジックを適用するより優れた方法である可能性があります。\n```\n\n1. メソッド名にカーソルを置きます。\n\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n\n3. 次のコマンドを入力します: `rewrite the condition to use a switch and use Java 21 syntax with null case, but also add documentation and provide a better function name`\n\n   これは、単一のプロンプトを使用して、Copilot に複数の変更を加えるように求める方法を示しています。\n\n4. ```\n          <kbd>Enter</kbd> キーを押します。\n   ```\n\n   Copilot は、修正されたコードを提案します。 次に例を示します。\n\n   ```java\n   /**\n    * Retrieves the sound made by a given animal.\n    * * @param animal The name of the animal.\n    * @return The sound made by the animal, or \"Unknown\" if the animal is not recognized.\n    */\n   public String getAnimalSound(String animal) {\n       return switch (animal) {\n           case null -> {\n               System.out.println(\"Oops! A null animal?\");\n               yield \"Unknown\";\n           }\n           case String a when a.equalsIgnoreCase(\"Dog\") -> \"Bark\";\n           case String a when a.equalsIgnoreCase(\"Cat\") -> \"Meow\";\n           case String a when a.equalsIgnoreCase(\"Bird\") -> \"Tweet\";\n           default -> \"Unknown\";\n       };\n   }\n   ```\n\n5. Copilot の提案を評価し、変更に同意する場合は、次の手順を実行します:\n\n   * **VS Code および Visual Studio では:** **\\[承諾]** をクリックします。\n   * **JetBrains**: プレビュー アイコン (二重矢印) をクリックし、\\[すべての差分の適用] アイコン (二重山かっこ) をクリックします。\n\nすべての Copilot の提案と同様に、修正されたコードがエラーなしで実行され、正しい結果が生成されることを常に確認する必要があります。\n\n## 別の構造を使用するようにコードを再フォーマットする\n\nJavaScript に次の関数があるとします:\n\n```javascript\nfunction listRepos(o, p) {\n return fetch(`https://api.github.com/orgs/${o}/repos?per_page=${parseInt(p)}`)\n   .then((response) => response.json())\n   .then( (data) => data);\n}\n```\n\nコーディング標準で関数の矢印表記とパラメーターにわかりやすい名前を使用する必要がある場合は、Copilot を使用して、これらの変更を行うことができます。\n\n1. 関数名にカーソルを置きます。\n2. インライン チャットを開きます:\n\n   * **VS Code:** <kbd>Command</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>i</kbd> (Windows/Linux) を押します。\n   * **Visual Studio:** <kbd>Alt</kbd>+<kbd>/</kbd> キーを押します。\n   * **JetBrains IDE:** <kbd>Control</kbd>+<kbd>Shift</kbd>+<kbd>i</kbd> (Mac) または <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>g</kbd> (Windows/Linux) を押します。\n3. 「`use arrow notation and better parameter names`」と入力して <kbd>Enter</kbd> キーを押します。\n\n   Copilot は、修正されたコードを提案します。 次に例を示します。\n\n   ```javascript\n   const listRepos = (org, perPage) => {\n     return fetch(`https://api.github.com/orgs/${org}/repos?per_page=${parseInt(perPage)}`)\n       .then(response => response.json())\n       .then(data => data);\n   };\n   ```\n\n## シンボルの名前の改善\n\n> \\[!NOTE]\n>\n> * VS Code および Visual Studio のみ。\n> * この機能のサポートは、使用している言語に合わせて IDE に適切な言語拡張機能をインストールするかどうかによって異なります。 すべての言語拡張機能でこの機能がサポートされているわけではありません。\n\n適切に選択された名前は、コードの保守を簡単にするのに役立ちます。 Copilot と VS Code の Visual Studio は、変数や関数などのシンボルの別名を提案できます。\n\n1. シンボル名にカーソルを置きます。\n\n2. ```\n          <kbd>F2</kbd>キーを押します。\n   ```\n\n3. ```\n          **Visual Studio のみ:**<kbd>Ctrl</kbd>+<kbd>Space</kbd> キーを押します。\n   ```\n\n   Copilot は、別名を提案します。\n\n   ![シンボル名の代わりに使用する VS Code のドロップダウン リストのスクリーンショット。](/assets/images/help/copilot/rename-symbol.png)\n\n4. ドロップダウン リストで、推奨される名前のいずれかを選択します。\n\n   プロジェクト全体で名前が変更されます。"}