Official Python SDK for the Sawalni API
Project description
Sawalni Python SDK
This is the official Python SDK for the Sawalni API, providing easy access to language-related services such as embedding generation, language identification, and translation. Sawalni API is developed by Omneity Labs, and provides unique multilingual models and NLP capabilities, including pioneering Moroccan Darija support.
Installation
Install the package using pip:
pip install sawalni
Quick Start
To use the Sawalni SDK, you'll need an API key. You can set it as an environment variable or pass it directly to the client:
from sawalni import Sawalni
client = Sawalni(api_key='your_api_key_here')
# or specify the key via SAWALNI_API_KEY in the environment
Features
The SDK supports both synchronous and asynchronous operations for the following services:
- Chat: Generate chat completions using our
Sawalni
multilingual models, supporting Moroccan Darija, English, French, Arabic and many other languages. - Search: Perform internet searches in multiple languages with a single query.
- Generate Embeddings: Create embeddings for text in multiple languages using
Madmon
. - Identify Language: Detect the language of a given text with
Gherbal
, supporting up to 33 languages. - Translate Text: Translate text between 13 supported languages with
Tarjamli
. - Transliterate Text: Convert Moroccan Arabic script to Moroccan Latin script with
Daktilo
.
The Sawalni SDK includes an OpenAI compatible client, which can be accessed via the chat
and embeddings
properties, or direct use via the OpenAI client as detailed below.
Chat
# Available models: sawalni-zero, sawalni-micro, sawalni-mini
chat = client.chat.completions.create(messages=[{"role": "user", "content": "Hello, how are you?"}], model="sawalni-zero")
# Stream
stream = client.chat.completions.create(messages=[{"role": "user", "content": "Hello, how are you?"}], model="sawalni-zero", stream=True)
for chunk in stream:
print(chunk.choices[0].delta.content)
Search
search = client.search("Hello, how are you?")
Generate Embeddings
embeddings = client.embed("Hello, world!")
Identify Language
language = client.identify("Bonjour le monde")
Translate Text
# You can specify a source language or let the model detect it automatically
translation = client.translate("Hello", source="auto", target="ary_Latn")
Transliterate Text
transliteration = client.transliterate("اهلا بيك", model="daktilo-mini", to="latn", temperature=0.1)
# {"text": "ahlane bik"}
Asynchronous Usage
For asynchronous operations, use the SawalniAsync client:
from sawalni import SawalniAsync
async_client = SawalniAsync(api_key='your_api_key_here')
embeddings = await async_client.embed("Hello, world!")
OpenAI compatible client
The SDK also includes an OpenAI compatible client, which can be accessed via the chat
and embeddings
properties:
chat = client.chat
embeddings = client.embeddings
You can also use the OpenAI client directly with the base URL set to https://api.sawalni.com/v1
and the API key set to your Sawalni API key.
import openai
client = openai.OpenAI(base_url="https://api.sawalni.com/v1", api_key="your_api_key_here")
Only the chat
and embeddings
properties are supported with this approach.
Documentation
For detailed information about available models, parameters, languages and and response formats, please refer to the complete API documentation at https://api.sawalni.com.
Support
If you encounter any issues or have questions, please contact api@sawalni.com.
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
File details
Details for the file sawalni-0.2.2.tar.gz
.
File metadata
- Download URL: sawalni-0.2.2.tar.gz
- Upload date:
- Size: 5.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c8d1ec2dbca330b2b44fb4c76afe52892a9df2cdf380fe8879d1a1c89971849 |
|
MD5 | 15d22ebdeb0ba9f691246496ed7e1d18 |
|
BLAKE2b-256 | 45c99698da6e70f0453971de0558aa99d989ab1d8aaab66589e81d25194aa911 |
File details
Details for the file sawalni-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: sawalni-0.2.2-py3-none-any.whl
- Upload date:
- Size: 5.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0157869c7bcfb9d1b6d622be9c1e8f24c791f32afc6219d97da7619ed6ffc8b3 |
|
MD5 | 620174b13321fdf59f358bfcfa5c734e |
|
BLAKE2b-256 | cf34f3c6b88915febda0d1db44db110295cbeb8744603157588ba8da6b0c44f3 |