This page provides an overview of common workflows for using the Twelve Labs JavaScript SDK. Each workflow consists of a series of steps, with links to detailed documentation for each step.
All workflows involving uploading video content to the platform require asynchronous processing. You must wait for the video processing to complete before proceeding with the subsequent steps.
Prerequisites
Ensure that the following prerequisites are met before using the Python SDK:
- Python 3.7 or newer must be installed on your machine.
- You have an API key. If you don't have an account, please sign up for a free account. Then, to retrieve your API key, go to the API Key page, and select the Copy icon to the right of the key to copy it to your clipboard.
Install the SDK
Install the twelvelabs-js
package:
pip install twelvelabs
Initialize the SDK
- Import the required packages:
from twelvelabs import TwelveLabs
- Instantiate the SDK client with your API key.:
client = TwelveLabs(api_key="<YOUR_API_KEY>")
Search
Follow the steps in this section to search your video content for specific moments, scenes, or information.
Steps:
- Create an index, enabling the Marengo video understanding engine.
- Upload videos and monitor the processing.
- Perform a search request, using text or images as queries.
Notes:
- The search scope is an individual index.
- Results support pagination, filtering, sorting, and grouping.
Classify
Follow the steps in this section to organize your videos into manageable and useful categories, making them easier to find, access, and use.
Steps:
- Create an index, enabling the Marengo video understanding engine.
- Upload videos and monitor the processing.
- Classify a set of videos or all the videos within an index.
Notes:
- Results support filtering and pagination.
Create text, image, and audio embeddings
This workflow guides you through creating embeddings for text.
Steps:
Notes:
- Creating text embeddings is a synchronous process.
Create video embeddings
This workflow guides you through creating embeddings for videos.
Steps:
- Upload a video and monitor the processing.
- Retrieve the embeddings.
Generate text from videos
Follow the steps in this section to generate texts based on your videos.
Steps:
- Create an index, enabling the Pegasus video understanding engine.
- Upload videos and monitor the processing.
- Depending on your use case, generate one of the following:
Note:
- When generating open-ended texts, the platform supports streaming responses.
Extract video data
Follow the steps in this guide to extract various types of data from your videos, such as transcriptions, on-screen text, logos, and thumbnails.
Steps:
- Create an index, enabling the Marengo video understanding engine.
- Upload videos and monitor the processing.
- Depending on your use case: