Skip to main content

Opper Python client

Project description

Opper Python SDK

This is the Opper Python SDK. See below for getting started, and the docs for more information. The SDK has builtin documentation and examples in function docstrings, which should be visible in your code editor as you are using the functions.

Install

pip install opperai

Configuration

Environment variable

  • OPPER_API_KEY environment variable is read by the SDK if no api_key is provided to the Client object.

Using opper

from typing import List

from opperai import Index, Opper, trace
from opperai.types import DocumentIn
from opperai.types.indexes import DocumentIn, RetrievalResponse
from pydantic import BaseModel


class Answer(BaseModel):
    steps: List[str]


class QuestionAndContext(BaseModel):
    question: str
    context: List[RetrievalResponse]


@trace
def answer_question(index: Index, question: str) -> Answer:
    results = index.query(question, 1, None)

    result, response = opper.call(
        name="answer_question",
        instructions="Answer the question and provide the steps to do so",
        input=QuestionAndContext(question=question, context=results),
        output_type=Answer,
    )
    response.span.save_metric("artificial_score", 5)

    return result


@trace
def translate(answer: Answer, language: str) -> str:
    result, _ = opper.call(
        name="translate",
        instructions="Translate the answer to the given language",
        input=answer,
        output_type=Answer,
    )
    return result


qna = [
    {
        "question": "I cannot log in to my account",
        "answer": "Use the reset password feature by clicking on 'Forgot password?' and then follow the instructions from email",
        "id": "1",
    },
    {
        "question": "How can I see my invoices?",
        "answer": "Go to the billing section and click on 'Invoices'",
        "id": "2",
    },
    {
        "question": "How can I add a new user to my account?",
        "answer": "Upgrade account and add the user to your account",
        "id": "3",
    },
]

opper = Opper()


def index_qna(qnas: list[dict]):
    index = opper.indexes.create("qna")

    for qna in qnas:
        index.add(
            DocumentIn(
                key=qna["id"],
                content=f"question: {qna['question']}\nanswer: {qna['answer']}",
                metadata={
                    "id": qna["id"],
                },
            )
        )

    return index


def run():
    index = index_qna(qna)

    question = "How can I see my invoices?"

    with opper.traces.start("answer_question") as trace:
        answer = answer_question(index, question)
        print(answer)


run()

More examples

See examples in our documentation and examples folder.

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

opperai-0.24.0.tar.gz (34.2 kB view details)

Uploaded Source

Built Distribution

opperai-0.24.0-py3-none-any.whl (54.9 kB view details)

Uploaded Python 3

File details

Details for the file opperai-0.24.0.tar.gz.

File metadata

  • Download URL: opperai-0.24.0.tar.gz
  • Upload date:
  • Size: 34.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for opperai-0.24.0.tar.gz
Algorithm Hash digest
SHA256 a3998ec751306dc98a3c534600393c7fa1f8b7fd360e0706394d8bab2ede3157
MD5 f58c401161d55d4ad5bd7196b42eabaa
BLAKE2b-256 411a662ded93553256e2e3d75df8efedfe8a8b00d91fa1f641a2fdbe7ccabfe4

See more details on using hashes here.

Provenance

The following attestation bundles were made for opperai-0.24.0.tar.gz:

Publisher: publish.yml on opper-ai/opper-python

Attestations:

File details

Details for the file opperai-0.24.0-py3-none-any.whl.

File metadata

  • Download URL: opperai-0.24.0-py3-none-any.whl
  • Upload date:
  • Size: 54.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for opperai-0.24.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7810b8d69510f2c492a7c5fb90837f29b5e3204260175361d2f2b774e0155cc6
MD5 572b98f74133cda5d6ad8213f28995db
BLAKE2b-256 138898d3ed7974c63a79846c0a2b49bbf15bdc1f7d8d19b4f61d8fce5ff7bee2

See more details on using hashes here.

Provenance

The following attestation bundles were made for opperai-0.24.0-py3-none-any.whl:

Publisher: publish.yml on opper-ai/opper-python

Attestations:

Supported by

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