-
Notifications
You must be signed in to change notification settings - Fork 2.6k
Expand file tree
/
Copy pathagent.py
More file actions
110 lines (87 loc) · 3.24 KB
/
agent.py
File metadata and controls
110 lines (87 loc) · 3.24 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import argparse
import os
import sys
from deepagents import create_deep_agent
from deepagents.backends import FilesystemBackend
from dotenv import load_dotenv
from langchain_anthropic import ChatAnthropic
from langchain_community.agent_toolkits import SQLDatabaseToolkit
from langchain_community.utilities import SQLDatabase
from rich.console import Console
from rich.panel import Panel
# Load environment variables
load_dotenv()
console = Console()
def create_sql_deep_agent():
"""Create and return a text-to-SQL Deep Agent"""
# Get base directory
base_dir = os.path.dirname(os.path.abspath(__file__))
# Connect to Chinook database
db_path = os.path.join(base_dir, "chinook.db")
db = SQLDatabase.from_uri(f"sqlite:///{db_path}", sample_rows_in_table_info=3)
# Initialize Claude Sonnet 4.5 for toolkit initialization
model = ChatAnthropic(model="claude-sonnet-4-5-20250929", temperature=0)
# Create SQL toolkit and get tools
toolkit = SQLDatabaseToolkit(db=db, llm=model)
sql_tools = toolkit.get_tools()
# Create the Deep Agent with all parameters
agent = create_deep_agent(
model=model, # Claude Sonnet 4.5 with temperature=0
memory=["./AGENTS.md"], # Agent identity and general instructions
skills=[
"./skills/"
], # Specialized workflows (query-writing, schema-exploration)
tools=sql_tools, # SQL database tools
subagents=[], # No subagents needed
backend=FilesystemBackend(root_dir=base_dir), # Persistent file storage
)
return agent
def main():
"""Main entry point for the SQL Deep Agent CLI"""
parser = argparse.ArgumentParser(
description="Text-to-SQL Deep Agent powered by LangChain Deep Agents and Claude Sonnet 4.5",
formatter_class=argparse.RawDescriptionHelpFormatter,
epilog="""
Examples:
python agent.py "What are the top 5 best-selling artists?"
python agent.py "Which employee generated the most revenue by country?"
python agent.py "How many customers are from Canada?"
""",
)
parser.add_argument(
"question",
type=str,
help="Natural language question to answer using the Chinook database",
)
args = parser.parse_args()
# Display the question
console.print(
Panel(f"[bold cyan]Question:[/bold cyan] {args.question}", border_style="cyan")
)
console.print()
# Create the agent
console.print("[dim]Creating SQL Deep Agent...[/dim]")
agent = create_sql_deep_agent()
# Invoke the agent
console.print("[dim]Processing query...[/dim]\n")
try:
result = agent.invoke(
{"messages": [{"role": "user", "content": args.question}]}
)
# Extract and display the final answer
final_message = result["messages"][-1]
answer = (
final_message.content
if hasattr(final_message, "content")
else str(final_message)
)
console.print(
Panel(f"[bold green]Answer:[/bold green]\n\n{answer}", border_style="green")
)
except Exception as e:
console.print(
Panel(f"[bold red]Error:[/bold red]\n\n{str(e)}", border_style="red")
)
sys.exit(1)
if __name__ == "__main__":
main()