Notatka
Dostęp do tej strony wymaga autoryzacji. Może spróbować zalogować się lub zmienić katalogi.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
Utwórz agenta i uzyskaj odpowiedź — w kilku wierszach kodu.
dotnet add package Azure.AI.Projects --prerelease
dotnet add package Azure.Identity
dotnet add package Microsoft.Agents.AI.Foundry --prerelease
Utwórz agenta:
using System;
using Azure.AI.Projects;
using Azure.Identity;
using Microsoft.Agents.AI;
var endpoint = Environment.GetEnvironmentVariable("AZURE_OPENAI_ENDPOINT")
?? throw new InvalidOperationException("Set AZURE_OPENAI_ENDPOINT");
var deploymentName = Environment.GetEnvironmentVariable("AZURE_OPENAI_DEPLOYMENT_NAME") ?? "gpt-4o-mini";
AIAgent agent = new AIProjectClient(new Uri(endpoint), new DefaultAzureCredential())
.AsAIAgent(
model: deploymentName,
instructions: "You are a friendly assistant. Keep your answers brief.",
name: "HelloAgent");
Ostrzeżenie
DefaultAzureCredential jest wygodne do programowania, ale wymaga starannego rozważenia w środowisku produkcyjnym. W środowisku produkcyjnym rozważ użycie określonego poświadczenia (np. ManagedIdentityCredential), aby uniknąć problemów z opóźnieniami, niezamierzonego sondowania poświadczeń i potencjalnych zagrożeń bezpieczeństwa wynikających z mechanizmów awaryjnych.
Uruchom go:
Console.WriteLine(await agent.RunAsync("What is the largest city in France?"));
Możesz też przesłać strumieniowo odpowiedź:
await foreach (var update in agent.RunStreamingAsync("Tell me a one-sentence fun fact."))
{
Console.Write(update);
}
Tip
Zobacz tutaj , aby zapoznać się z pełną aplikacją przykładową z możliwością uruchamiania.
pip install agent-framework
Tworzenie i uruchamianie agenta:
client = FoundryChatClient(
project_endpoint="https://your-project.services.ai.azure.com",
model="gpt-4o",
credential=AzureCliCredential(),
)
agent = Agent(
client=client,
name="HelloAgent",
instructions="You are a friendly assistant. Keep your answers brief.",
)
# Non-streaming: get the complete response at once
result = await agent.run("What is the capital of France?")
print(f"Agent: {result}")
Możesz też przesłać strumieniowo odpowiedź:
# Streaming: receive tokens as they are generated
print("Agent (streaming): ", end="", flush=True)
async for chunk in agent.run("Tell me a one-sentence fun fact.", stream=True):
if chunk.text:
print(chunk.text, end="", flush=True)
print()
Uwaga / Notatka
Struktura agenta nie ładuje plików .env automatycznie. Aby użyć .env pliku do konfiguracji, wykonaj load_dotenv() na początku skryptu.
from dotenv import load_dotenv
load_dotenv()
Alternatywnie ustaw zmienne środowiskowe bezpośrednio w powłoce lub środowisku IDE. Zobacz notatkę dotyczącą migracji ustawień , aby uzyskać szczegółowe informacje.
Tip
Zapoznaj się z pełnym przykładem kompletnego pliku możliwego do uruchomienia.
Dalsze kroki
Głębiej:
- Omówienie agentów — zrozumienie architektury agenta
- Dostawcy — zobacz wszystkich obsługiwanych dostawców