Gemini
Video Input (File Upload)
Examples
- Introduction
- Getting Started
- Agents
- Teams
- Workflows
- Applications
Agent Concepts
- Multimodal
- RAG
- Knowledge
- Memory
- Async
- Hybrid Search
- Storage
- Tools
- Vector Databases
- Embedders
Models
- Anthropic
- AWS Bedrock
- AWS Bedrock Claude
- Azure AI Foundry
- Azure OpenAI
- Cohere
- DeepInfra
- DeepSeek
- Fireworks
- Gemini
- Basic Agent
- Streaming Agent
- Agent with Structured Outputs
- Agent with Tools
- Agent with Storage
- Agent with Knowledge
- Image Agent
- Flash Thinking Agent
- Audio Input (Bytes Content)
- Audio Input (Upload the file)
- Audio Input (Local file)
- Agent with PDF Input (Local file)
- Agent with PDF Input (URL)
- Video Input (Bytes Content)
- Video Input (File Upload)
- Video Input (Local File Upload)
- Groq
- Hugging Face
- Mistral
- NVIDIA
- Ollama
- OpenAI
- Perplexity
- Together
- xAI
- IBM
- LM Studio
- LiteLLM
- LiteLLM OpenAI
Gemini
Video Input (File Upload)
Code
cookbook/models/google/gemini/video_input_file_upload.py
import time
from pathlib import Path
from agno.agent import Agent
from agno.media import Video
from agno.models.google import Gemini
from agno.utils.log import logger
model = Gemini(id="gemini-2.0-flash-exp")
agent = Agent(
model=model,
markdown=True,
)
# Please download a sample video file to test this Agent
# Run: `wget https://storage.googleapis.com/generativeai-downloads/images/GreatRedSpot.mp4` to download a sample video
video_path = Path(__file__).parent.joinpath("samplevideo.mp4")
video_file = None
remote_file_name = f"files/{video_path.stem.lower().replace('_', '')}"
try:
video_file = model.get_client().files.get(name=remote_file_name)
except Exception as e:
logger.info(f"Error getting file {video_path.stem}: {e}")
pass
# Upload the video file if it doesn't exist
if not video_file:
try:
logger.info(f"Uploading video: {video_path}")
video_file = model.get_client().files.upload(
file=video_path,
config=dict(name=video_path.stem, display_name=video_path.stem),
)
# Check whether the file is ready to be used.
while video_file.state.name == "PROCESSING":
time.sleep(2)
video_file = model.get_client().files.get(name=video_file.name)
logger.info(f"Uploaded video: {video_file}")
except Exception as e:
logger.error(f"Error uploading video: {e}")
if __name__ == "__main__":
agent.print_response(
"Tell me about this video",
videos=[Video(content=video_file)],
stream=True,
)
Usage
1
Create a virtual environment
Open the Terminal
and create a python virtual environment.
python3 -m venv .venv
source .venv/bin/activate
2
Set your API key
export GOOGLE_API_KEY=xxx
3
Install libraries
pip install -U google-genai agno
4
Run Agent
python cookbook/models/google/gemini/video_input_file_upload.py