این درس نحوه اجرای نمونه کدهای این دوره را پوشش میدهد.
قبل از شروع به کلون کردن مخزن خود، به کانال AI Agents For Beginners Discord بپیوندید تا در تنظیمات، سوالات مربوط به دوره یا ارتباط با دیگر یادگیرندگان کمک بگیرید.
برای شروع، لطفاً مخزن گیتهاب را کلون یا فورک کنید. این کار نسخهٔ شخصی خود از مطالب دوره را ایجاد میکند تا بتوانید کد را اجرا، آزمون و تنظیم کنید!
این کار با کلیک روی لینک فورک مخزن انجام میشود.
اکنون باید نسخهٔ فورک شده خود از این دوره را در لینک زیر داشته باشید:

مخزن کامل ممکن است بزرگ (~۳ گیگابایت) باشد هنگام دانلود تمام سابقه و فایلها. اگر فقط در کارگاه شرکت میکنید یا فقط به چند پوشه درس نیاز دارید، کلون کمعمق (یا کلون پراکنده) با قطع تاریخچه و/یا کاهش بارهای داده بیشتر از دانلود بزرگ جلوگیری میکند.
در دستورات زیر <your-username> را با آدرس فورک خود (یا آدرس اصلی اگر ترجیح میدهید) جایگزین کنید.
برای کلون فقط تاریخچه آخرین کامیت (دانلود کوچک):
git clone --depth 1 https://github.com/<your-username>/ai-agents-for-beginners.git
برای کلون شاخهٔ خاص:
git clone --depth 1 --branch <branch-name> https://github.com/<your-username>/ai-agents-for-beginners.git
این روش از کلون جزئی و sparse-checkout استفاده میکند (نیاز به گیت 2.25+ و گیت مدرن با پشتیبانی کلون جزئی دارد):
git clone --depth 1 --filter=blob:none --sparse https://github.com/<your-username>/ai-agents-for-beginners.git
به پوشه مخزن بروید:
cd ai-agents-for-beginners
سپس مشخص کنید کدام پوشهها را میخواهید (مثال زیر دو پوشه را نشان میدهد):
git sparse-checkout set 00-course-setup 01-intro-to-ai-agents
بعد از کلون کردن و بررسی فایلها، اگر فقط به فایلها نیاز دارید و میخواهید فضا آزاد کنید (بدون تاریخچه گیت)، لطفاً متادیتای مخزن را حذف کنید (💀غیرقابل بازگشت — تمام عملکردهای Git از جمله کامیت، پول، پوش و دسترسی به تاریخچه را از دست خواهید داد).
# زد شل / بش
rm -rf .git
# پاورشل
Remove-Item -Recurse -Force .git
یک کداسپیس جدید برای این مخزن از طریق رابط کاربری GitHub ایجاد کنید.
این دوره مجموعهای از نوتبوکهای Jupyter ارائه میدهد که میتوانید برای کسب تجربه عملی در ساخت عوامل هوش مصنوعی اجرا کنید.
نمونه کدها از Microsoft Agent Framework (MAF) با AzureAIProjectAgentProvider استفاده میکنند، که به Azure AI Agent Service V2 (API پاسخها) از طریق Microsoft Foundry متصل میشود.
تمام نوتبوکهای پایتون با *-python-agent-framework.ipynb برچسبگذاری شدهاند.
توجه: اگر پایتون 3.12 نصب ندارید، آن را نصب کنید. سپس venv خود را با python3.12 ایجاد کنید تا نسخههای صحیح از فایل requirements.txt نصب شود.
مثال
ایجاد پوشه محیط مجازی پایتون:
python -m venv venv
سپس برای فعال کردن محیط venv:
# zsh/bash
source venv/bin/activate
# Command Prompt for Windows
venv\Scripts\activate
.NET 10+: برای کدهای نمونه استفاده شده در داتنت، مطمئن شوید .NET 10 SDK یا بالاتر نصب شده است. سپس نسخه نصب شده .NET SDK خود را بررسی کنید:
dotnet --list-sdks
gpt-4o). نگاه کنید به مرحله ۱ پایین.ما فایل requirements.txt را در ریشه مخزن قرار دادهایم که شامل تمام بستههای پایتون لازم برای اجرای نمونههاست.
میتوانید با اجرای دستور زیر در ترمینال و در ریشه مخزن آنها را نصب کنید:
pip install -r requirements.txt
پیشنهاد میکنیم محیط مجازی پایتون بسازید تا از تعارضها و مشکلات جلوگیری شود.
مطمئن شوید که در VSCode از نسخه درست پایتون استفاده میکنید.
برای اجرای نوتبوکها نیاز به هاب و پروژه Azure AI Foundry با مدلی مستقر دارید.
۱. به ai.azure.com بروید و با حساب Azure خود وارد شوید.
۲. یک هاب ایجاد کنید (یا از یکی موجود استفاده کنید). ببینید: نمای کلی منابع هاب.
۳. درون هاب، یک پروژه بسازید.
۴. یک مدل را از Models + Endpoints → Deploy model مستقر کنید (مثلاً gpt-4o).
از پروژه خود در پرتال Microsoft Foundry:

gpt-4o) را یادداشت کنید.az loginتمام نوتبوکها برای احراز هویت از AzureCliCredential استفاده میکنند — نیازی به مدیریت کلیدهای API نیست. این مستلزم ورود شما از طریق Azure CLI است.
۱. Azure CLI را نصب کنید اگر نصب ندارید: aka.ms/installazurecli
۲. وارد شوید با اجرای:
```bash|powershell
az login
```
یا اگر در محیط دور از میز/کداسپیس بدون مرورگر هستید:
```bash|powershell
az login --use-device-code
```
۳. اشتراک خود را انتخاب کنید اگر خواسته شد — اشتراکی که پروژه Foundry شما است را انتخاب کنید.
۴. تأیید کنید که وارد شدهاید:
```bash|powershell
az account show
```
چرا
az login؟ نوتبوکها با استفاده ازAzureCliCredentialاز بستهazure-identityاحراز هویت میکنند. این یعنی جلسه Azure CLI شما اعتبارنامهها را فراهم میکند — بدون کلید API یا اسرار در فایل.env. این یک بهترین روش امنیتی است.
.envفایل نمونه را کپی کنید:
# زد شل/بش
cp .env.example .env
# پاورشل
Copy-Item .env.example .env
فایل .env را باز کنید و این دو مقدار را پر کنید:
AZURE_AI_PROJECT_ENDPOINT=https://<your-project>.services.ai.azure.com/api/projects/<your-project-id>
AZURE_AI_MODEL_DEPLOYMENT_NAME=gpt-4o
| متغیر | محل یافتن |
|---|---|
AZURE_AI_PROJECT_ENDPOINT |
پرتال Foundry → پروژه شما → صفحه Overview |
AZURE_AI_MODEL_DEPLOYMENT_NAME |
پرتال Foundry → Models + Endpoints → نام مدل مستقر شدهتان |
همین! برای بیشتر درسها نوتبوکها به صورت خودکار از طریق جلسه az login شما احراز هویت میکنند.
pip install -r requirements.txt
پیشنهاد میکنیم این کار را داخل محیط مجازی که قبلاً ساختید انجام دهید.
درس ۵ از Azure AI Search برای تولید تقویتشده بازیابی استفاده میکند. اگر قصد اجرای آن درس را دارید، این متغیرها را به فایل .env خود اضافه کنید:
| متغیر | محل یافتن |
|---|---|
AZURE_SEARCH_SERVICE_ENDPOINT |
پرتال Azure → منبع Azure AI Search شما → Overview → URL |
AZURE_SEARCH_API_KEY |
پرتال Azure → منبع Azure AI Search شما → Settings → Keys → کلید اصلی ادمین |
برخی نوتبوکها در درسهای ۶ و ۸ به جای Azure AI Foundry از مدلهای GitHub استفاده میکنند. اگر قصد اجرای آن نمونهها را دارید، این متغیرها را به فایل .env اضافه کنید:
| متغیر | محل یافتن |
|---|---|
GITHUB_TOKEN |
GitHub → Settings → Developer settings → Personal access tokens |
GITHUB_ENDPOINT |
از https://models.inference.ai.azure.com (مقدار پیشفرض) استفاده کنید |
GITHUB_MODEL_ID |
نام مدل مورد استفاده (مثلاً gpt-4o-mini) |
MiniMax مدلهای با زمینه بزرگ (تا ۲۰۴ هزار نشانه) را از طریق API سازگار با OpenAI ارائه میدهد. از آنجا که OpenAIChatClient در Microsoft Agent Framework با هر نقطه انتهایی سازگار با OpenAI کار میکند، میتوانید MiniMax را به عنوان جایگزینی برای مدلهای GitHub یا OpenAI استفاده کنید.
این متغیرها را به فایل .env خود اضافه کنید:
| متغیر | محل یافتن |
|---|---|
MINIMAX_API_KEY |
پلتفرم MiniMax → کلیدهای API |
MINIMAX_BASE_URL |
از https://api.minimax.io/v1 (مقدار پیشفرض) استفاده کنید |
MINIMAX_MODEL_ID |
نام مدل مورد استفاده (مثلاً MiniMax-M2.7) |
مدلهای موجود: MiniMax-M2.7 (توصیه شده)، MiniMax-M2.7-highspeed (پاسخهای سریعتر)
نمونه کدهایی که OpenAIChatClient را استفاده میکنند (مثلاً جریان کاری رزرو هتل درس ۱۴) به طور خودکار تنظیمات MiniMax شما را وقتی MINIMAX_API_KEY تنظیم شده تشخیص و استفاده خواهند کرد.
نوتبوک جریان کاری شرطی در درس ۸ از Bing grounding از طریق Azure AI Foundry استفاده میکند. اگر قصد اجرای این نمونه را دارید، این متغیر را به فایل .env اضافه کنید:
| متغیر | محل یافتن |
|---|---|
BING_CONNECTION_ID |
پرتال Azure AI Foundry → پروژه شما → مدیریت → منابع متصل شده → اتصال Bing شما → شناسه اتصال را کپی کنید |
اگر در macOS با اروری مانند زیر مواجه شدید:
ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: self-signed certificate in certificate chain
این یک مشکل شناخته شده با پایتون در macOS است که گواهیهای SSL سیستم به طور خودکار اعتماد نمیشوند. راهحلهای زیر را به ترتیب امتحان کنید:
گزینه ۱: اجرای اسکریپت نصب گواهیهای Python (توصیه شده)
# نسخه پایتون نصب شده خود را جایگزین 3.XX کنید (برای مثال، 3.12 یا 3.13):
/Applications/Python\ 3.XX/Install\ Certificates.command
گزینه ۲: استفاده از connection_verify=False در نوتبوک خود (فقط برای نوتبوکهای مدلهای GitHub)
در نوتبوک درس ۶ (06-building-trustworthy-agents/code_samples/06-system-message-framework.ipynb)، یک راهحل موقت کامنتشده وجود دارد. هنگام ساخت کلاینت، connection_verify=False را از حالت کامنت خارج کنید:
client = ChatCompletionsClient(
endpoint=endpoint,
credential=AzureKeyCredential(token),
connection_verify=False, # در صورت مواجهه با خطاهای گواهی، تأیید SSL را غیرفعال کنید
)
⚠️ هشدار: غیرفعال کردن اعتبارسنجی SSL (
connection_verify=False) امنیت را کاهش میدهد زیرا اعتبارسنجی گواهی را رد میکند. این فقط به عنوان راهحل موقت در محیط توسعه استفاده شود، هرگز در محیط تولید.
گزینه ۳: نصب و استفاده از truststore
pip install truststore
سپس این را در بالای نوتبوک یا اسکریپت قبل از هر فراخوانی شبکه قرار دهید:
import truststore
truststore.inject_into_ssl()
اگر در اجرای این راهاندازی مشکلی داشتید، به کانال Discord جامعه Azure AI بپیوندید یا یک مسئله ایجاد کنید.
اکنون آمادهاید کد این دوره را اجرا کنید. با آرزوی موفقیت در یادگیری دنیای عوامل هوش مصنوعی!
مقدمهای بر عوامل هوش مصنوعی و موارد استفاده آنها
سلب مسئولیت:
این سند با استفاده از سرویس ترجمه هوش مصنوعی Co-op Translator ترجمه شده است. در حالی که ما در تلاش برای دقت هستیم، لطفاً توجه داشته باشید که ترجمههای خودکار ممکن است حاوی خطاها یا نادرستیهایی باشند. سند اصلی به زبان مادری آن باید به عنوان منبع معتبر در نظر گرفته شود. برای اطلاعات حیاتی، ترجمه حرفهای انسانی توصیه میشود. ما مسئول هیچ گونه سوء تفاهم یا تفسیر نادرستی که از استفاده این ترجمه ناشی شود، نیستیم.