A Python package providing programmatic access to Poe.com model data with pricing information
Project description
Virginia Clemm Poe
A Python package providing programmatic access to Poe.com model data with pricing information.
∞ Overview
Virginia Clemm Poe is a companion tool for Poe.com's API (introduced August 25, 2024) that fetches and maintains comprehensive model data including pricing information. The package provides both a Python API for querying model data and a CLI for updating the dataset.
This link points to the data file that is updated by the virginia-clemm-poe CLI tool. Note: this is a static copy, does not reflect the latest data from Poe’s API.
∞
∞ Features
- Model Data Access: Query Poe.com models by various criteria including ID, name, and other attributes
- Bot Information: Captures bot creator, description, and additional metadata
- Pricing Information: Automatically scrapes and syncs pricing data for all available models
- Pydantic Models: Fully typed data models for easy integration
- CLI Interface: Fire-based CLI for updating data and searching models
- Browser Automation: Powered by PlaywrightAuthor with Chrome for Testing support
- Session Reuse: Maintains authenticated browser sessions across script runs for efficient scraping
∞ Installation
pip install virginia-clemm-poe
∞ Quick Start
∞ Python API
from virginia_clemm_poe import api
# Search for models
models = api.search_models("claude")
for model in models:
print(f"{model.id}: {model.get_primary_cost()}")
# Get model by ID
model = api.get_model_by_id("claude-3-opus")
if model and model.pricing:
print(f"Cost: {model.get_primary_cost()}")
print(f"Updated: {model.pricing.checked_at}")
# Get all models with pricing
priced_models = api.get_models_with_pricing()
print(f"Found {len(priced_models)} models with pricing")
∞ Programmatic Session Reuse
from virginia_clemm_poe.browser_pool import BrowserPool
# Use session reuse for authenticated scraping
async def scrape_with_session_reuse():
pool = BrowserPool(reuse_sessions=True)
await pool.start()
# Get a page that reuses existing authenticated session
page = await pool.get_reusable_page()
await page.goto("https://poe.com/some-protected-page")
# You're already logged in!
await pool.stop()
∞ Command Line Interface
# Set up browser for web scraping
virginia-clemm-poe setup
# Update model data (bot info + pricing) - default behavior
export POE_API_KEY=your_api_key
virginia-clemm-poe update
# Update only bot info (creator, description)
virginia-clemm-poe update --info
# Update only pricing information
virginia-clemm-poe update --pricing
# Force update all data even if it exists
virginia-clemm-poe update --force
# Search for models
virginia-clemm-poe search "gpt-4"
# Search with bot info displayed
virginia-clemm-poe search "claude" --show-bot-info
# List all models with summary
virginia-clemm-poe list
# List only models with pricing
virginia-clemm-poe list --with-pricing
NAME
__main__.py - Virginia Clemm Poe - Poe.com model data management CLI.
SYNOPSIS
__main__.py COMMAND
DESCRIPTION
A comprehensive tool for accessing and maintaining Poe.com model information with
pricing data. Use 'virginia-clemm-poe COMMAND --help' for detailed command info.
Quick Start:
1. virginia-clemm-poe setup # One-time browser installation
2. virginia-clemm-poe update # Fetch/refresh model data
3. virginia-clemm-poe search # Query models by name/ID
Common Workflows:
- Initial Setup: setup → update → search
- Regular Use: search (data cached locally)
- Maintenance: status → update (if needed)
- Troubleshooting: doctor → follow recommendations
COMMANDS
COMMAND is one of the following:
cache
Monitor cache performance and hit rates - optimize your API usage.
clear_cache
Clear cache and stored data - use when experiencing stale data issues.
doctor
Diagnose and fix common issues - run this when something goes wrong.
list
List all available models - get an overview of the entire dataset.
search
Find models by name or ID - your primary command for discovering models.
setup
Set up Chrome browser for web scraping - required before first update.
status
Check system health and data freshness - your go-to diagnostic command.
update
Fetch latest model data from Poe - run weekly or when new models appear.
∞ Session Reuse Workflow (Recommended)
Virginia Clemm Poe now supports PlaywrightAuthor's session reuse feature, which maintains authenticated browser sessions across script runs. This is particularly useful for scraping data that requires login.
# Step 1: Launch Chrome for Testing and log in manually
playwrightauthor browse
# Step 2: In the browser window that opens, log into Poe.com
# The browser stays running after you close the terminal
# Step 3: Run virginia-clemm-poe commands - they'll reuse the authenticated session
export POE_API_KEY=your_api_key
virginia-clemm-poe update --pricing
# The scraper will reuse your logged-in session for faster, more reliable data collection
This approach provides several benefits:
- One-time authentication: Log in once manually, then all scripts use that session
- Faster scraping: No need to handle login flows in automation
- More reliable: Avoids bot detection during login
∞ API Reference
∞ Core Functions
∞ api.search_models(query: str) -> List[PoeModel]
Search for models by ID or name (case-insensitive).
∞ api.get_model_by_id(model_id: str) -> Optional[PoeModel]
Get a specific model by its ID.
∞ api.get_all_models() -> List[PoeModel]
Get all available models.
∞ api.get_models_with_pricing() -> List[PoeModel]
Get all models that have pricing information.
∞ api.get_models_needing_update() -> List[PoeModel]
Get models that need pricing update.
∞ api.reload_models() -> ModelCollection
Force reload models from disk.
∞ Data Models
∞ PoeModel
class PoeModel:
id: str
created: int
owned_by: str
root: str
parent: Optional[str]
architecture: Architecture
pricing: Optional[Pricing]
pricing_error: Optional[str]
bot_info: Optional[BotInfo]
def has_pricing() -> bool
def needs_pricing_update() -> bool
def get_primary_cost() -> Optional[str]
∞ Architecture
class Architecture:
input_modalities: List[str]
output_modalities: List[str]
modality: str
∞ BotInfo
class BotInfo:
creator: Optional[str] # e.g., "@openai"
description: Optional[str] # Main bot description
description_extra: Optional[str] # Additional disclaimer text
∞ Pricing
class Pricing:
checked_at: datetime
details: PricingDetails
∞ PricingDetails
Flexible pricing details supporting various cost structures:
- Standard fields:
input_text,input_image,bot_message,chat_history - Alternative fields:
total_cost,image_output,video_output, etc. - Bot info field:
initial_points_cost(e.g., "206+ points")
∞ CLI Commands
∞ setup
Set up browser for web scraping (handled automatically by PlaywrightAuthor).
virginia-clemm-poe setup
∞ update
Update model data from Poe API and scrape additional information.
virginia-clemm-poe update [--info] [--pricing] [--all] [--force] [--verbose]
Options:
--info: Update only bot info (creator, description)--pricing: Update only pricing information--all: Update both info and pricing (default: True)--api_key: Override POE_API_KEY environment variable--force: Force update even if data exists--debug_port: Chrome debug port (default: 9222)--verbose: Enable verbose logging
By default, the update command updates both bot info and pricing. Use --info or --pricing to update only specific data.
∞ search
Search for models by ID or name.
virginia-clemm-poe search "claude" [--show-pricing] [--show-bot-info]
Options:
--show-pricing: Show pricing information if available (default: True)--show-bot-info: Show bot info (creator, description) (default: False)
∞ list
List all available models.
virginia-clemm-poe list [--with-pricing] [--limit 10]
Options:
--with-pricing: Only show models with pricing information--limit: Limit number of results
∞ Requirements
- Python 3.12+
- Chrome or Chromium browser (automatically managed by PlaywrightAuthor)
- Poe API key (set as
POE_API_KEYenvironment variable)
∞ Data Storage
Model data is stored in src/virginia_clemm_poe/data/poe_models.json within the package directory. The data includes:
- Basic model information (ID, name, capabilities)
- Detailed pricing structure
- Timestamps for data freshness
∞ Development
∞ Setting Up Development Environment
# Clone the repository
git clone https://github.com/twardoch/virginia-clemm-poe.git
cd virginia-clemm-poe
# Install uv (if not already installed)
curl -LsSf https://astral.sh/uv/install.sh | sh
# Create virtual environment and install dependencies
uv venv --python 3.12
source .venv/bin/activate # On Windows: .venv\Scripts\activate
uv pip install -e ".[dev]"
# Set up browser for development
virginia-clemm-poe setup
∞ Running Tests
# Run all tests
python -m pytest
# Run with coverage
python -m pytest --cov=virginia_clemm_poe
∞ Dependencies
This package uses:
uvfor dependency managementhttpxfor API requestsplaywrightauthorfor browser automationpydanticfor data modelsfirefor CLI interfacerichfor terminal UIlogurufor logginghatch-vcsfor automatic versioning from git tags
∞ API Examples
∞ Get Model Information
from virginia_clemm_poe import api
# Get a specific model
model = api.get_model_by_id("claude-3-opus")
if model:
print(f"Model: {model.id}")
print(f"Input modalities: {model.architecture.input_modalities}")
if model.pricing:
primary_cost = model.get_primary_cost()
print(f"Cost: {primary_cost}")
print(f"Last updated: {model.pricing.checked_at}")
# Search for models
gpt_models = api.search_models("gpt")
for model in gpt_models:
print(f"- {model.id}: {model.architecture.modality}")
∞ Filter Models by Criteria
from virginia_clemm_poe import api
# Get all models with pricing
priced_models = api.get_models_with_pricing()
print(f"Models with pricing: {len(priced_models)}")
# Get models needing pricing update
need_update = api.get_models_needing_update()
print(f"Models needing update: {len(need_update)}")
# Get models with specific modality
all_models = api.get_all_models()
text_to_image = [m for m in all_models if m.architecture.modality == "text->image"]
print(f"Text-to-image models: {len(text_to_image)}")
∞ Working with Pricing Data
from virginia_clemm_poe import api
# Get pricing details for a model
model = api.get_model_by_id("claude-3-haiku")
if model and model.pricing:
details = model.pricing.details
# Access standard pricing fields
if details.input_text:
print(f"Text input: {details.input_text}")
if details.bot_message:
print(f"Bot message: {details.bot_message}")
# Alternative pricing formats
if details.total_cost:
print(f"Total cost: {details.total_cost}")
# Get primary cost (auto-detected)
print(f"Primary cost: {model.get_primary_cost()}")
∞ Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
∞ Author
Adam Twardoch adam+github@twardoch.com
∞ License
Licensed under the Apache License 2.0. See LICENSE file for details.
∞ Acknowledgments
Named after Virginia Clemm Poe (1822–1847), wife of Edgar Allan Poe, reflecting the connection to Poe.com.
∞ Disclaimer
This is an unofficial companion tool for Poe.com's API. It is not affiliated with or endorsed by Poe.com or Quora, Inc.
Project details
Release history Release notifications | RSS feed
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 virginia_clemm_poe-1.0.29.tar.gz.
File metadata
- Download URL: virginia_clemm_poe-1.0.29.tar.gz
- Upload date:
- Size: 1.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b7f1c3aa99b51ed3462393d62f868115e7686c591ccbae0b20cdc5f2c1d257b6
|
|
| MD5 |
433322db52e7ad54e3c1430f2b5885d2
|
|
| BLAKE2b-256 |
ab4e43f1a0c16280d91bad0f8c5aad37b9594d9e635367f753458d109729515b
|
File details
Details for the file virginia_clemm_poe-1.0.29-py3-none-any.whl.
File metadata
- Download URL: virginia_clemm_poe-1.0.29-py3-none-any.whl
- Upload date:
- Size: 142.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3980cbf7700944412c0d5071063901a62d5a77558b70fd0f34ca54b8ba06b10c
|
|
| MD5 |
d060e398a7635cbb840be9b3ae0be8a6
|
|
| BLAKE2b-256 |
0fd97c7dbc16400cfbaaf4c4c42dcc219c367197d81b7988f040d240163eb6fb
|