> ## Documentation Index
> Fetch the complete documentation index at: https://docs.dify.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# レッスン 9：レイアウトデザイナー（テンプレート）

> このドキュメントは AI によって自動翻訳されています。不正確な部分がある場合は、[英語版](/en/learn/tutorials/workflow-101/lesson-09) を参照してください。

レッスン 8 では、思考と検索ができる強力なエージェントを構築しました。しかし、小さな問題に気づいたかもしれません。最後の LLM に回答をリスト形式で出力するよう指示しても、フォーマットが乱れたり統一されなかったりすることがあります（例：箇条書きと段落が混在するなど）。

この問題を解決するために、最終的な LLM がメールを作成する前に、回答を美しく統一されたフォーマットに整理する専用のフォーマットアシスタントが必要です。

## テンプレート変換

テンプレート変換は、元のデータ（回答リストなど）を受け取り、あなたが指定した厳密なデザインテンプレート/基準に従って、完璧にフォーマットされたテキストブロックを生成します。毎回一貫した出力が保証されます。

## ハンズオン：メールのレイアウトを整える

<Steps>
  <Step title="LLM ノードを更新する">
    テンプレートノードが挨拶文を担当するため、LLM には質問と回答だけに集中するよう指示する必要があります。以下のプロンプトをコピー＆ペーストするか、自由に編集してください。

    ```plaintext wrap theme={null}
    Combine all answers for the original email. Write a complete, clear, and friendly reply that only includes the summarized answers.

    IMPORTANT: Focus SOLELY on the answers. Do NOT include greetings (like "Hi Name"), do
    NOT write intro paragraphs (like "Thank you for reaching out"), and do NOT include
    signatures.
    ```
  </Step>

  <Step title="ユーザーメッセージを追加する">
    それぞれの変数をリストアップして挿入します。

    <Frame>
      <img src="https://mintcdn.com/dify-6c0370d8/W-660XSNevX1HYUo/images/use-dify/tutorial/workflow-101-lesson-09/edit-llm-node.png?fit=max&auto=format&n=W-660XSNevX1HYUo&q=85&s=dcae9bf39f55060aebf8053f364745ba" alt="LLM ノードを編集" width="1476" height="1126" data-path="images/use-dify/tutorial/workflow-101-lesson-09/edit-llm-node.png" />
    </Frame>
  </Step>

  <Step title="テンプレートノードを追加する">
    LLM ノードの後に、クリックしてテンプレートノードを追加します。

    <Frame>
      <img src="https://mintcdn.com/dify-6c0370d8/W-660XSNevX1HYUo/images/use-dify/tutorial/workflow-101-lesson-09/add-template-node.png?fit=max&auto=format&n=W-660XSNevX1HYUo&q=85&s=aee89fa176e8cd47cf105f810701a656" alt="テンプレートノードを追加" width="1006" height="216" data-path="images/use-dify/tutorial/workflow-101-lesson-09/add-template-node.png" />
    </Frame>
  </Step>

  <Step title="入力変数を設定する">
    テンプレートノードをクリックし、入力変数（Input Variables）セクションに移動して、以下の 2 つの項目を追加します：

    * `customer`：`User Input / {x} customer_name String` を選択
    * `body`：`LLM / {x} text String` を選択

          <Frame>
            <img src="https://mintcdn.com/dify-6c0370d8/W-660XSNevX1HYUo/images/use-dify/tutorial/workflow-101-lesson-09/template-input-variable.png?fit=max&auto=format&n=W-660XSNevX1HYUo&q=85&s=4e37016e7867986ee8f33f9a5b5ed65e" alt="テンプレート入力変数" width="1222" height="510" data-path="images/use-dify/tutorial/workflow-101-lesson-09/template-input-variable.png" />
          </Frame>
  </Step>

  <Step title="Jinja でフォーマットする">
    **Jinja2 とは？**

    簡単に言うと、Jinja2 は変数（回答リストなど）を希望通りのフォーマットでテキストテンプレートに挿入できるツールです。シンプルな記号を使って変数の配置場所を指定し、基本的なロジックを実行します。これにより、生のデータリストを整然とした統一フォーマットのテキストブロックに変換できます。

    ここでは、冒頭の挨拶、署名、メール本文を組み合わせて、毎回プロフェッショナルで一貫したメールを作成できるようにします。

    以下のレイアウトをそのままテンプレートのコードボックスにコピー＆ペーストしてください：

    ```jinja theme={null}
    Hi {{ customer }},

    Thank you for reaching out to us, and we are more than happy to provide you with the information you are seeking.

    Here are the details regarding your specific questions:

    {{ body }}

    ---
    Thank you for reaching out to us!
    Best regards,
    Anne
    ```
  </Step>
</Steps>

最終的なワークフローはこちらです。

<Frame>
  <img src="https://mintcdn.com/dify-6c0370d8/W-660XSNevX1HYUo/images/use-dify/tutorial/workflow-101-lesson-09/the-final-workflow.png?fit=max&auto=format&n=W-660XSNevX1HYUo&q=85&s=6a689dd125d91c93ec44e24e4a9bbe61" alt="最終ワークフロー" width="2524" height="390" data-path="images/use-dify/tutorial/workflow-101-lesson-09/the-final-workflow.png" />
</Frame>

**テスト実行** をクリックします。1 通のメールに複数の質問を入れてみてください。最終出力には、カスタマイズされた冒頭の挨拶、LLM が美しくまとめた回答、そして標準的でプロフェッショナルな署名が完璧に含まれていることに気づくでしょう。

## ミニチャレンジ

1. Jinja2 のコードを変更して、箇条書きの代わりに番号付きリスト（1. 回答、2. 回答）にするにはどうすればよいでしょうか？

   <Tip>
     [Template Designer Documentation](https://jinja.palletsprojects.com/en/stable/templates/) を参照するか、LLM に聞いてみましょう。
   </Tip>
2. テンプレートノードには他にどのような活用方法があるでしょうか？
