from pathlib import Path
from agno.agent import Agent
from agno.media import Audio
from agno.models.google import Gemini
model = Gemini(id="gemini-2.0-flash-exp")
agent = Agent(
model=model,
markdown=True,
)
# 请下载一个音频文件样本用于测试此 Agent,并使用以下方式上传:
audio_path = Path(__file__).parent.joinpath("sample.mp3")
audio_file = None
remote_file_name = f"files/{audio_path.stem.lower()}"
try:
audio_file = model.get_client().files.get(name=remote_file_name)
except Exception as e:
print(f"Error getting file {audio_path.stem}: {e}")
pass
if not audio_file:
try:
audio_file = model.get_client().files.upload(
file=audio_path,
config=dict(name=audio_path.stem, display_name=audio_path.stem),
)
print(f"Uploaded audio: {audio_file}")
except Exception as e:
print(f"Error uploading audio: {e}")
agent.print_response(
"Tell me about this audio",
audio=[Audio(content=audio_file)],
stream=True,
)
创建虚拟环境
打开 Terminal
并创建一个 python 虚拟环境。
python3 -m venv .venv
source .venv/bin/activate
设置您的 API 密钥
export GOOGLE_API_KEY=xxx
安装库
pip install -U google-genai agno
运行 Agent
python cookbook/models/google/gemini/audio_input_file_upload.py