LangChain Few-Shot Prompt Templates(two)

https://python.langchain.com.cn/docs/modules/model_io/prompts/prompt_templates/few_shot_examples

This demo shows how the example selector picks the most relevant example to help the LLM answer a user's question effectively.

Step 1: Understand What We're Building

We'll create a tool that:

  • Uses "semantic similarity" to find the most relevant example for a user's question (instead of using all examples).
  • Teaches the LLM to answer questions by first asking follow-ups (just like the examples).
  • Produces a clear, step-by-step answer to a real user question.

Complete Code Demo

python 复制代码
# 1. Import tools we need (from the original text's Part 2)
from langchain.prompts.few_shot import FewShotPromptTemplate
from langchain.prompts.prompt import PromptTemplate
from langchain.prompts.example_selector import SemanticSimilarityExampleSelector
from langchain.vectorstores import Chroma
from langchain.embeddings import OpenAIEmbeddings
from langchain.chat_models import ChatOpenAI
import os

# 2. Set your OpenAI API key (get one from https://platform.openai.com/)
os.environ["OPENAI_API_KEY"] = "your-openai-api-key-here"

# 3. Define our few-shot examples (same as original text)
examples = [
  {
    "question": "Who lived longer, Muhammad Ali or Alan Turing?",
    "answer": 
"""
Are follow up questions needed here: Yes.
Follow up: How old was Muhammad Ali when he died?
Intermediate answer: Muhammad Ali was 74 years old when he died.
Follow up: How old was Alan Turing when he died?
Intermediate answer: Alan Turing was 41 years old when he died.
So the final answer is: Muhammad Ali
"""
  },
  {
    "question": "When was the founder of craigslist born?",
    "answer": 
"""
Are follow up questions needed here: Yes.
Follow up: Who was the founder of craigslist?
Intermediate answer: Craigslist was founded by Craig Newmark.
Follow up: When was Craig Newmark born?
Intermediate answer: Craig Newmark was born on December 6, 1952.
So the final answer is: December 6, 1952
"""
  },
  {
    "question": "Who was the maternal grandfather of George Washington?",
    "answer":
"""
Are follow up questions needed here: Yes.
Follow up: Who was the mother of George Washington?
Intermediate answer: The mother of George Washington was Mary Ball Washington.
Follow up: Who was the father of Mary Ball Washington?
Intermediate answer: The father of Mary Ball Washington was Joseph Ball.
So the final answer is: Joseph Ball
"""
  },
  {
    "question": "Are both the directors of Jaws and Casino Royale from the same country?",
    "answer":
"""
Are follow up questions needed here: Yes.
Follow up: Who is the director of Jaws?
Intermediate Answer: The director of Jaws is Steven Spielberg.
Follow up: Where is Steven Spielberg from?
Intermediate Answer: The United States.
Follow up: Who is the director of Casino Royale?
Intermediate Answer: The director of Casino Royale is Martin Campbell.
Follow up: Where is Martin Campbell from?
Intermediate Answer: New Zealand.
So the final answer is: No
"""
  }
]

# 4. Create the "example formatter" (how each example is displayed)
example_prompt = PromptTemplate(
    input_variables=["question", "answer"],
    template="Question: {question}\n{answer}"  # Format: "Question: X\nAnswer: Y"
)

# 5. Create the Example Selector (the key part from Part 2!)
# This finds the example most similar to the user's question
example_selector = SemanticSimilarityExampleSelector.from_examples(
    examples,  # Our list of examples
    OpenAIEmbeddings(),  # Converts text to "meaning numbers" (to check similarity)
    Chroma,  # Stores these numbers to quickly find matches
    k=1  # Pick only the 1 most similar example
)

# 6. Create the few-shot prompt template (using the selector)
prompt = FewShotPromptTemplate(
    example_selector=example_selector,  # Use the selector instead of all examples
    example_prompt=example_prompt,  # How to format the selected example
    suffix="Question: {input}",  # The user's question at the end
    input_variables=["input"]  # The user's question is called "input"
)

# 7. Define the user's question (let's ask something similar to our examples)
user_question = "Who was the paternal grandfather of George Washington?"

# 8. Generate the full prompt (with only the most relevant example)
full_prompt = prompt.format(input=user_question)
print("=== Generated Prompt (with 1 relevant example) ===")
print(full_prompt)
print("\n=== LLM's Answer ===")

# 9. Use the LLM to generate a response
llm = ChatOpenAI(model_name="gpt-3.5-turbo", temperature=0)  # "temperature=0" = consistent answers
response = llm.predict(full_prompt)
print(response)

What You'll See When You Run It

复制代码
=== Generated Prompt (with 1 relevant example) ===
Question: Who was the maternal grandfather of George Washington?

Are follow up questions needed here: Yes.
Follow up: Who was the mother of George Washington?
Intermediate answer: The mother of George Washington was Mary Ball Washington.
Follow up: Who was the father of Mary Ball Washington?
Intermediate answer: The father of Mary Ball Washington was Joseph Ball.
So the final answer is: Joseph Ball


Question: Who was the paternal grandfather of George Washington?

=== LLM's Answer ===
Are follow up questions needed here: Yes.
Follow up: Who was the father of George Washington?
Intermediate answer: The father of George Washington was Augustine Washington.
Follow up: Who was the father of Augustine Washington?
Intermediate answer: The father of Augustine Washington was Lawrence Washington.
So the final answer is: Lawrence Washington

Simple Explanation

  1. Example Selector: Instead of shoving all 4 examples into the prompt, we use a "smart selector." It checks which example is most like the user's question (using "meaning numbers" from the embedding model) and only includes that one. This keeps the prompt short and focused.

  2. How It Works for Our Question : The user asked about George Washington's paternal grandfather . The selector noticed our 3rd example was about his maternal grandfather (similar topic!) and picked that one.

  3. LLM Follows the Pattern: The LLM sees the selected example and copies its style: first asking follow-ups ("Who was George Washington's father?"), then finding intermediate answers, and finally giving a clear final answer.

Why This Matters

  • Faster & More Accurate: The LLM doesn't waste time reading irrelevant examples.
  • Scalable: If you have 100 examples, the selector will still pick the 1 best one---no need to clutter the prompt.

Just replace "your-openai-api-key-here" with your actual API key, and you're good to go!

相关推荐
FserSuN2 小时前
LangChain DeepAgent 多 Agent 架构原理学习
架构·langchain
前进的李工5 小时前
LangChain使用AI工具赋能:解锁大语言模型无限潜力
开发语言·人工智能·语言模型·langchain·大模型
万物得其道者成7 小时前
Cursor 提效实战:我的前端 Prompt、审查 SKILL、MCP 接入完整方法
前端·prompt
杨艺韬7 小时前
为什么需要理解 LangChain
langchain·agent
坤岭8 小时前
大模型“入侵”广告推荐
人工智能·langchain·推荐算法
deephub8 小时前
Prompt、Context、Harness:AI Agent 工程的三层架构解析
人工智能·prompt·大语言模型·context
嵌入式-小王9 小时前
LangChain框架(二)---- 提示词模板
python·langchain
zhangshuang-peta9 小时前
MCP 与 Prompt Engineering:协议出现后,Prompt 还重要吗?
人工智能·prompt·ai agent·mcp·peta
来一斤小鲜肉9 小时前
一文搞懂:如何用 Spring AI 搭建 MCP Server 和 Client
后端·langchain
bKYP953cL11 小时前
Prompt 缓存的四种策略:从精确匹配到语义检索
spring·缓存·prompt