* Add new AI content types and image tool support Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Add Python content types for tool calls/results and image generation tool support Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Address review feedback for tool content and samples Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Tighten image generation typing and sample tools list Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Align image generation output typing Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Handle MCP naming, image options mapping, and connector tool content Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Allow MCP call in function approval request Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Remove raw image_generation tool remapping Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Restore Anthropic tool_use to function calls unless code execution Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Fix lint issues for hosted file docstring and MCP parsing Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Import ChatResponse types in Anthropic client Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Fix Anthropics citation type imports and MCP typing for handoff/tools Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * Skip lightning tests without agentlightning and fix function call import Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> * fix lint on lab package * rebuilt anthropic parsing * redid anthropic parsing * typo * updated parsing and added missing docstrings * fix tests * mypy fixes * second mypy fix * add new class to other samples --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: eavanvalkenburg <13749212+eavanvalkenburg@users.noreply.github.com> Co-authored-by: eavanvalkenburg <github@vanvalkenburg.eu>
Azure AI Agent Examples
This folder contains examples demonstrating different ways to create and use agents with the Azure AI client from the agent_framework.azure package. These examples use the AzureAIClient with the azure-ai-projects 2.x (V2) API surface (see changelog). For V1 (azure-ai-agents 1.x) samples using AzureAIAgentClient, see the Azure AI V1 examples folder.
Examples
| File | Description |
|---|---|
azure_ai_basic.py |
The simplest way to create an agent using AzureAIClient. Demonstrates both streaming and non-streaming responses with function tools. Shows automatic agent creation and basic weather functionality. |
azure_ai_use_latest_version.py |
Demonstrates how to reuse the latest version of an existing agent instead of creating a new agent version on each instantiation using the use_latest_version=True parameter. |
azure_ai_with_agent_to_agent.py |
Shows how to use Agent-to-Agent (A2A) capabilities with Azure AI agents to enable communication with other agents using the A2A protocol. Requires an A2A connection configured in your Azure AI project. |
azure_ai_with_azure_ai_search.py |
Shows how to use Azure AI Search with Azure AI agents to search through indexed data and answer user questions with proper citations. Requires an Azure AI Search connection and index configured in your Azure AI project. |
azure_ai_with_bing_grounding.py |
Shows how to use Bing Grounding search with Azure AI agents to search the web for current information and provide grounded responses with citations. Requires a Bing connection configured in your Azure AI project. |
azure_ai_with_bing_custom_search.py |
Shows how to use Bing Custom Search with Azure AI agents to search custom search instances and provide responses with relevant results. Requires a Bing Custom Search connection and instance configured in your Azure AI project. |
azure_ai_with_browser_automation.py |
Shows how to use Browser Automation with Azure AI agents to perform automated web browsing tasks and provide responses based on web interactions. Requires a Browser Automation connection configured in your Azure AI project. |
azure_ai_with_code_interpreter.py |
Shows how to use the HostedCodeInterpreterTool with Azure AI agents to write and execute Python code for mathematical problem solving and data analysis. |
azure_ai_with_code_interpreter_file_generation.py |
Shows how to retrieve file IDs from code interpreter generated files using both streaming and non-streaming approaches. |
azure_ai_with_existing_agent.py |
Shows how to work with a pre-existing agent by providing the agent name and version to the Azure AI client. Demonstrates agent reuse patterns for production scenarios. |
azure_ai_with_existing_conversation.py |
Demonstrates how to use an existing conversation created on the service side with Azure AI agents. Shows two approaches: specifying conversation ID at the client level and using AgentThread with an existing conversation ID. |
azure_ai_with_application_endpoint.py |
Demonstrates calling the Azure AI application-scoped endpoint. |
azure_ai_with_explicit_settings.py |
Shows how to create an agent with explicitly configured AzureAIClient settings, including project endpoint, model deployment, and credentials rather than relying on environment variable defaults. |
azure_ai_with_file_search.py |
Shows how to use the HostedFileSearchTool with Azure AI agents to upload files, create vector stores, and enable agents to search through uploaded documents to answer user questions. |
azure_ai_with_hosted_mcp.py |
Shows how to integrate hosted Model Context Protocol (MCP) tools with Azure AI Agent. |
azure_ai_with_local_mcp.py |
Shows how to integrate local Model Context Protocol (MCP) tools with Azure AI agents. |
azure_ai_with_response_format.py |
Shows how to use structured outputs (response format) with Azure AI agents using Pydantic models to enforce specific response schemas. |
azure_ai_with_runtime_json_schema.py |
Shows how to use structured outputs (response format) with Azure AI agents using a JSON schema to enforce specific response schemas. |
azure_ai_with_search_context_agentic.py |
Shows how to use AzureAISearchContextProvider with agentic mode. Uses Knowledge Bases for multi-hop reasoning across documents with query planning. Recommended for most scenarios - slightly slower with more token consumption for query planning, but more accurate results. |
azure_ai_with_search_context_semantic.py |
Shows how to use AzureAISearchContextProvider with semantic mode. Fast hybrid search with vector + keyword search and semantic ranking for RAG. Best for simple queries where speed is critical. |
azure_ai_with_sharepoint.py |
Shows how to use SharePoint grounding with Azure AI agents to search through SharePoint content and answer user questions with proper citations. Requires a SharePoint connection configured in your Azure AI project. |
azure_ai_with_thread.py |
Demonstrates thread management with Azure AI agents, including automatic thread creation for stateless conversations and explicit thread management for maintaining conversation context across multiple interactions. |
azure_ai_with_image_generation.py |
Shows how to use the ImageGenTool with Azure AI agents to generate images based on text prompts. |
azure_ai_with_memory_search.py |
Shows how to use memory search functionality with Azure AI agents for conversation persistence. Demonstrates creating memory stores and enabling agents to search through conversation history. |
azure_ai_with_microsoft_fabric.py |
Shows how to use Microsoft Fabric with Azure AI agents to query Fabric data sources and provide responses based on data analysis. Requires a Microsoft Fabric connection configured in your Azure AI project. |
azure_ai_with_openapi.py |
Shows how to integrate OpenAPI specifications with Azure AI agents using dictionary-based tool configuration. Demonstrates using external REST APIs for dynamic data lookup. |
azure_ai_with_web_search.py |
Shows how to use the HostedWebSearchTool with Azure AI agents to perform web searches and retrieve up-to-date information from the internet. |
Environment Variables
Before running the examples, you need to set up your environment variables. You can do this in one of two ways:
Option 1: Using a .env file (Recommended)
-
Copy the
.env.examplefile from thepythondirectory to create a.envfile:cp ../../../../.env.example ../../../../.env -
Edit the
.envfile and add your values:AZURE_AI_PROJECT_ENDPOINT="your-project-endpoint" AZURE_AI_MODEL_DEPLOYMENT_NAME="your-model-deployment-name"
Option 2: Using environment variables directly
Set the environment variables in your shell:
export AZURE_AI_PROJECT_ENDPOINT="your-project-endpoint"
export AZURE_AI_MODEL_DEPLOYMENT_NAME="your-model-deployment-name"
Required Variables
AZURE_AI_PROJECT_ENDPOINT: Your Azure AI project endpoint (required for all examples)AZURE_AI_MODEL_DEPLOYMENT_NAME: The name of your model deployment (required for all examples)
Authentication
All examples use AzureCliCredential for authentication by default. Before running the examples:
- Install the Azure CLI
- Run
az loginto authenticate with your Azure account - Ensure you have appropriate permissions to the Azure AI project
Alternatively, you can replace AzureCliCredential with other authentication options like DefaultAzureCredential or environment-based credentials.
Running the Examples
Each example can be run independently. Navigate to this directory and run any example:
python azure_ai_basic.py
python azure_ai_with_code_interpreter.py
# ... etc
The examples demonstrate various patterns for working with Azure AI agents, from basic usage to advanced scenarios like thread management and structured outputs.