Skip to main content

Library for managing and caching Google Docs prompts with templating support.

Project description

PromptStorage 🚀

Назначение

Библиотека prompt-storage предназначена для ускорения разработки проектов путем распараллеливания процессов создания кода и работы промпт-инженеров.

Элегантное решение для управления промптами из Google Docs с кешированием и шаблонизацией

PromptStorage – это мощная и гибкая библиотека, которая превращает Google Docs в вашу персональную базу промптов для работы с языковыми моделями. Забудьте о хардкоде промптов в коде или о сложных системах управления контентом – используйте знакомый всем Google Docs для создания, редактирования и управления промптами в удобном интерфейсе!

🌟 Основные преимущества

  • Интеграция с Google Docs – храните промпты там, где их удобно редактировать
  • Интеллектуальное кеширование – мгновенный доступ к промптам даже без интернета
  • Гибкая шаблонизация – поддержка Jinja2 и Mako для динамического контента
  • Встроенная интеграция с FastAPI – создавайте API для промптов за минуты
  • Простота использования – получение и обработка промптов всего за несколько строк кода
  • Оптимизация производительности – кеширование минимизирует запросы к API

📦 Установка

Базовая установка

pip install prompt-storage

Установка с поддержкой API (FastAPI)

pip install "prompt-storage[api]"

Установка в Google Colab (избегая конфликтов)

!pip install --no-dependencies prompt-storage
!pip install google-api-python-client google-auth google-auth-oauthlib python-docx jinja2 mako
# Для работы с API:
# !pip install fastapi

🚀 Быстрый старт

from prompt_storage import PromptStorage
from prompt_storage.template_processor import TemplateProcessor

# Инициализация хранилища промптов
storage = PromptStorage(
    credentials_path="credentials.json",
    token_path="token.json",
    cache_dir="./cache"
)

# Получение промпта по ID документа
prompt = storage.get_prompt("your_google_doc_id")

# Обработка промпта как шаблона
template_processor = TemplateProcessor()
processed_prompt = template_processor.process_template(
    prompt, 
    {"variable": "value", "user_name": "Иван"},
    template_engine="jinja2"
)

print(processed_prompt)

💡 Ключевые возможности

Google Docs Processor

from prompt_storage import GoogleDocsProcessor

# Инициализация процессора Google Docs
processor = GoogleDocsProcessor(
    credentials_path="credentials.json",
    token_path="token.json"
)

# Загрузка документа
document = processor.get_document("your_google_doc_id")

# Извлечение текста
text = processor.extract_text(document)

Управление кешем

from prompt_storage import GoogleDocsCacheManager

# Инициализация менеджера кеша
cache_manager = GoogleDocsCacheManager(cache_dir="./cache")

# Сохранение в кеш
cache_manager.save_to_cache("doc_id", "document_content")

# Проверка наличия в кеше
is_cached = cache_manager.is_cached("doc_id")

# Получение из кеша
content = cache_manager.get_from_cache("doc_id")

Шаблонизация

from prompt_storage import TemplateProcessor

# Инициализация процессора шаблонов
template_processor = TemplateProcessor()

# Jinja2 шаблонизация
jinja_result = template_processor.process_template(
    "Привет, {{ user_name }}! Ваш баланс: {{ balance }}.",
    {"user_name": "Иван", "balance": "1000₽"},
    "jinja2"
)

# Mako шаблонизация
mako_result = template_processor.process_template(
    "Привет, ${user_name}! Ваш баланс: ${balance}.",
    {"user_name": "Иван", "balance": "1000₽"},
    "mako"
)

🔧 Настройка доступа к Google API

  1. Создайте проект в Google Cloud Console
  2. Включите Google Docs API для вашего проекта
  3. Создайте учетные данные OAuth2 и скачайте файл credentials.json
  4. При первом запуске библиотеки, будет запрошена авторизация через браузер

📊 Варианты использования

  • Управление промптами для LLM – централизованное хранение и версионирование промптов
  • Создание многоязычных интерфейсов – шаблоны с поддержкой переменных для локализации
  • Системы генерации контента – динамические промпты для создания разнообразного контента
  • Автоматизация рутинных задач – промпты для различных бизнес-процессов

📜 Лицензия

MIT


Упростите управление промптами уже сегодня! 🚀

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

prompt_storage-0.1.7.post17.tar.gz (13.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

prompt_storage-0.1.7.post17-py3-none-any.whl (14.0 kB view details)

Uploaded Python 3

File details

Details for the file prompt_storage-0.1.7.post17.tar.gz.

File metadata

  • Download URL: prompt_storage-0.1.7.post17.tar.gz
  • Upload date:
  • Size: 13.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for prompt_storage-0.1.7.post17.tar.gz
Algorithm Hash digest
SHA256 2fbb0b32469be4c631519c6dfb988eaa889dc6d5e523e817c82de01cec2afc06
MD5 c2aa8d6b8895a24732fd72054c0f8fdc
BLAKE2b-256 b6bdffda2dafe95e6d7a6c3048c886b39a5dc3622b2e02cfabbda1298ee44b45

See more details on using hashes here.

File details

Details for the file prompt_storage-0.1.7.post17-py3-none-any.whl.

File metadata

File hashes

Hashes for prompt_storage-0.1.7.post17-py3-none-any.whl
Algorithm Hash digest
SHA256 8d7be53e45835bcc0da5e25348ad26faffa6381bd254f189b6cf5d4545b2c1f7
MD5 f638c6a420bcb536d7243b56fe03fd0a
BLAKE2b-256 cf99ee6dfe86602aa234e8ee17db3066e08c2b76fd2679b8c19df05f9af6c2b3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page