A Python package that provides an easier user interface for multiple LLM providers.
Project description
azllm: A Unified LLM Interface for Multi-Provider Access
azllm is a Python package that provides a unified interface to work with multiple LLM providers including OpenAI, DeepSeek, Grok, Gemini, Meta's LLaMA, Anthropic, Ollama, and more.
NOTE: For advanced usage, see the
azllmdocumentation and/or examples.
Features
- One unified interface for all major LLM APIs
- Batch and parallel prompt generation
- Structured outputs (parsing) with Pydantic for models that support parsed outputs natively
- Structured outputs (parsing) with Pydantic for DeepSeek and Anthropic
- Per-model configurations and lazy initialization
- Clean error handling
.env-based API key management
Supported Clients
NOTE: If you would like to request support for additional LLMs, please open an issue on our GitHub page.
Installation
You can install the azllm package via pip:
pip install azllm
Prerequisites
-
Python 3.11+
-
Create a
.envfile to store your API keys. For example:OPENAI_API_KEY=your_openai_api_key DEEPSEEK_API_KEY=your_deepseek_api_key XAI_API_KEY=your_xai_api_key GEMINI_API_KEY=your_gemini_api_key ANTHROPIC_API_KEY=your_anthropic_api_key FIREWORKS_API_KEY=your_fireworks_api_key
-
Ollama must be installed and running locally to use Ollama models.
Quick Start
Basic Initialization
from azllm import azLLM
manager = azLLM() # Instantiated with default parameters
Generate Text from a Single Prompt
prompt = 'What is the captial of France?'
generated_text = manager.generate_text('openai', prompt)
print(generated_text)
Batch Generation
Generate responses for multiple prompts at once:
batch_prompts = [
'What is the capital of France?',
'Tell me a joke.'
]
results = manager.batch_generate('openai', batch_prompts)
for result in results:
print(result)
Parallel Generation
Run a single prompt across multiple models simultaneously:
prompt = 'What is the capital of France?'
models = [
'openai',
'grok',
'ollama']
results = manager.generate_parallel(prompt, models)
for model, result in results.items():
print(f"Model: {model},\nResult: {result}\n")
License
MIT License
Citation
@misc{azLLM,
title = {azllm},
author = {Hanif Sajid and Benjamin Radford and Yaoyao Dai and Jason Windett},
year = {2025},
month = apr,
version = {0.1.5},
howpublished = {https://github.com/hanifsajid/azllm},
note = {MIT License},
abstract = {azllm is a Python package designed to interface with various large language models (LLMs) from different AI providers. It offers a unified interface for interacting with models from providers like OpenAI, DeepSeek, Grok, Gemini, Meta's Llama, Anthropic, Ollama, and others. The package allows for customizable configurations, batch generation, parallel generation, error handling, and the ability to parse structured responses from different models.}
}
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file azllm-0.1.5.tar.gz.
File metadata
- Download URL: azllm-0.1.5.tar.gz
- Upload date:
- Size: 15.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.3 CPython/3.11.13 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b910821f6b26cd893ebbc3930103dc9110ceb811b73a4175944866d0812499be
|
|
| MD5 |
f0be651dff70f2ceff62b67b1c9f2769
|
|
| BLAKE2b-256 |
6d5659b9cd4306c790451016dbbec6215418379fa3281b0749f2cb17ab9aeab0
|
File details
Details for the file azllm-0.1.5-py3-none-any.whl.
File metadata
- Download URL: azllm-0.1.5-py3-none-any.whl
- Upload date:
- Size: 27.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.3 CPython/3.11.13 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f0035217e678e33fbc754cf49dc04f1acfbba154dd23f517df06a2e4fdca3e2e
|
|
| MD5 |
b903ce0154eaa69c56e92e6b76e8d411
|
|
| BLAKE2b-256 |
f67b5108b958dbadbb1cacdb8cf5e02f9654147c73f62b168215ddc1a7e75e8c
|