The Unstructured UI features a no-code user interface for transforming your unstructured data into data that is ready for retrieval-augmented generation (RAG). The workflow operations in the Unstructured API enable a full range of partitioning, chunking, embedding, and enrichment options for your files and data. They are designed to batch-process files and data in remote locations; send processed results to various storage, databases, and vector stores; and use the latest and highest-performing models. These workflow operations have built-in logic to deliver the highest quality results at the lowest cost. This page provides an overview of the Unstructured API’s workflow operations. These operations enable Unstructured UI automation usage scenarios as well as for documentation, reporting, and recovery needs.Documentation Index
Fetch the complete documentation index at: https://docs.unstructured.io/llms.txt
Use this file to discover all available pages before exploring further.
Getting started
Choose one of the following options to get started with the Unstructured API’s workflow operations:- Follow the quickstart or walkthrough, which use the Unstructured Python SDK from remotely hosted Google Colab notebooks. These notebooks require no local setup.
- Start using the Unstructred Python SDK. This option requires you to set up a local Python virtual environment.
- Start using a local REST client, such as
curlor Postman.
Quickstart
The following quickstart shows how to use the Unstructured Python SDK to have Unstructured process local files by using the Unstructured API’s on-demand jobs functionality. This functionality is part of the Unstructured API’s collection of workflow operations. This quickstart is available in two options:- Use a remote notebook - This option uses a remotely hosted Google Colab notebook. There are no additional setup steps required.
- Use your local machine - This option requires you to install the Unstructured Python SDK on your local machine.
The on-demand jobs functionality is designed to work only by processing local files.To process files (and data) in remote file and blob storage, databases, and vector stores, you must use other
workflow operations in the Unstructured API. To learn how, see for example the notebook
Dropbox-To-Pinecone Connector API Quickstart for Unstructured.
Walkthrough
This walkthrough builds upon the quickstart. Like the quickstart, this walkthrough shows how to use the Unstructured Python SDK to have Unstructured process local files by using the Unstructured API’s on-demand jobs functionality. This walkthrough goes further by also showing in depth how to use Unstructured’s chunking, enriching, and embedding features. This walkthrough is available as a remotely hosted Google Colab notebook. This notebook requires no local setup.The on-demand jobs functionality is designed to work only by processing local files.To process files (and data) in remote file and blob storage, databases, and vector stores, you must use other
workflow operations in the Unstructured API. To learn how, see for example the notebook
Dropbox-To-Pinecone Connector API Quickstart for Unstructured.
Unstructured Python SDK
Watch the following 4-minute video to learn how to use the Python SDK to call the Unstructured API’s workflow operations to create connectors in the Unstructured UI.
Watch the following 4-minute video to learn how to use the Python SDK to call the Unstructured API’s workflow operations to
create workflows and jobs in the Unstructured UI.
Open a related notebook that covers many of
the concepts that are shown in the preceding videos.
The Unstructured Python SDK, beginning with version 0.30.6,
allows you to call the Unstructured API’s workflow operations through standard Python code.
To install the Unstructured Python SDK, run the following command from within your Python virtual environment:
-
If you do not already have an Unstructured account, sign up for free.
After you sign up, you are automatically signed in to your new Unstructured Let’s Go account, at https://platform.unstructured.io.
To sign up for a Business account instead, contact Unstructured Sales, or learn more.
-
If you have an Unstructured Let’s Go, Pay-As-You-Go, or Business SaaS account and are not already signed in, sign in to your account at https://platform.unstructured.io.
For other types of Business accounts, see your Unstructured account administrator for sign-in instructions, or email Unstructured Support at support@unstructured.io.
-
Get your Unstructured API key:
a. After you sign in to your Unstructured Let’s Go, Pay-As-You-Go, or Business account, click API Keys on the sidebar.
b. Click Generate API Key.For a Business account, before you click API Keys, make sure you have selected the organizational workspace you want to create an API key for. Each API key works with one and only one organizational workspace. Learn more.
c. Follow the on-screen instructions to finish generating the key.
d. Click the Copy icon next to your new key to add the key to your system’s clipboard. If you lose this key, simply return and click the Copy icon again.
unstructured_client functions for creating, listing, updating,
and deleting connectors, workflows, and jobs in the Unstructured UI all use the Unstructured API’s workflow operations URL.
This URL was provided to you when your Unstructured account was created.
If you do not have this URL, email Unstructured Support at support@unstructured.io.
The default URL for the Unstructured API’s workflow operations is
https://platform.unstructuredapp.io/api/v1.
However, you should always use the URL that was provided to you when your Unstructured account was created.server_url parameter in the UnstructuredClient constructor to the target API URL.
The Unstructured API’s workflow operations enable you to work with connectors,
workflows, and jobs in the Unstructured UI.
- A source connector ingests files or data into Unstructured from a source location.
- A destination connector sends the processed data from Unstructured to a destination location.
- A workflow defines how Unstructured will process the data.
- A job runs a workflow at a specific point in time.
REST endpoints
The Unstructured API’s workflow operations are callable from a set of Representational State Transfer (REST) endpoints, which you can call through standard REST-enabled utilities, tools, programming languages, packages, and libraries. The examples, shown later on this page and on related pages, describe how to call the Unstructured API’s workflow operations withcurl and Postman. You can adapt this information as needed for your preferred programming languages and libraries, for example by using the
requests library with Python.
curl and Postman
The followingcurl examples use the following environment variables, which you can set as follows:
The default URL for the Unstructured API’s workflow operations is
https://platform.unstructuredapp.io/api/v1.
However, you should always use the URL that was provided to you when your Unstructured account was created.curl examples and help prevent
you from storing scripts that contain sensitive URLs and API keys in public source code repositories.
To get your Unstructured API key, do the following:
-
If you do not already have an Unstructured account, sign up for free.
After you sign up, you are automatically signed in to your new Unstructured Let’s Go account, at https://platform.unstructured.io.
To sign up for a Business account instead, contact Unstructured Sales, or learn more.
-
If you have an Unstructured Let’s Go, Pay-As-You-Go, or Business SaaS account and are not already signed in, sign in to your account at https://platform.unstructured.io.
For other types of Business accounts, see your Unstructured account administrator for sign-in instructions, or email Unstructured Support at support@unstructured.io.
-
Get your Unstructured API key:
a. After you sign in to your Unstructured Let’s Go, Pay-As-You-Go, or Business account, click API Keys on the sidebar.
b. Click Generate API Key.For a Business account, before you click API Keys, make sure you have selected the organizational workspace you want to create an API key for. Each API key works with one and only one organizational workspace. Learn more.
c. Follow the on-screen instructions to finish generating the key.
d. Click the Copy icon next to your new key to add the key to your system’s clipboard. If you lose this key, simply return and click the Copy icon again.
- In Postman, on your workspace’s sidebar, click Environments.
- Click Globals.
-
Create two global variables with the following settings:
- Variable:
UNSTRUCTURED_API_URL - Type:
default - Initial value: The Unstructured API’s workflow operations URL that was provided to you when your Unstructured account was created.
- Current value: The Unstructured API’s workflow operations URL that was provided to you when your Unstructured account was created.
- Variable:
UNSTRUCTURED_API_KEY - Type:
secret - Initial value:
<your-unstructured-api-key> - Current value:
<your-unstructured-api-key>
- Variable:
- Click Save.
- Install Postman.
- Sign in to Postman.
-
In your workspace, click Import.

-
In the Paste cURL, Raw text or URL box, enter the following URL, and then press
Enter: For all workflow operations:For on-demand job related operations only:Each on-demand job is limited to 10 files, and each file is limited to 10 MB in size.If you need to launch a series of on-demand jobs in rapid succession, you must wait at least one second between launch requests. Otherwise, you will receive a rate limit error.A maximum of 5 on-demand jobs can be running in your Unstructured account. If you launch a new on-demand job but 5 existing on-demand jobs are still running, the new on-demand job will remain in a scheduled state until one of the 5 existing on-demand jobs is done running. - On the sidebar, click Collections.
- Expand Unstructured REST API - Workflow Operations.
- Select the request that you want to use.
- As applicable, modify the URL as needed to specify any required resource IDs for the request.
-
On the Headers tab, next to
unstructured-api-key, enter your Unstructured API key in the Value column. As applicable, add, remove, or modify any other required headers for the request. - As applicable, on the Params tab, add, remove, or modify any required parameters for the request.
- As applicable, on the Body tab, add, remove, or modify the required request body for the request.
- Click Send.
- To save the response, in the response area, click the ellipses, and then click Save response to file.
-
If you do not already have an Unstructured account, sign up for free.
After you sign up, you are automatically signed in to your new Unstructured Let’s Go account, at https://platform.unstructured.io.
To sign up for a Business account instead, contact Unstructured Sales, or learn more.
-
If you have an Unstructured Let’s Go, Pay-As-You-Go, or Business SaaS account and are not already signed in, sign in to your account at https://platform.unstructured.io.
For other types of Business accounts, see your Unstructured account administrator for sign-in instructions, or email Unstructured Support at support@unstructured.io.
-
Get your Unstructured API key:
a. After you sign in to your Unstructured Let’s Go, Pay-As-You-Go, or Business account, click API Keys on the sidebar.
b. Click Generate API Key.For a Business account, before you click API Keys, make sure you have selected the organizational workspace you want to create an API key for. Each API key works with one and only one organizational workspace. Learn more.
c. Follow the on-screen instructions to finish generating the key.
d. Click the Copy icon next to your new key to add the key to your system’s clipboard. If you lose this key, simply return and click the Copy icon again.
- A source connector ingests files or data into Unstructured from a source location.
- A destination connector sends the processed data from Unstructured to a destination location.
- A workflow defines how Unstructured will process the data.
- A job runs a workflow at a specific point in time.
Restrictions
The following Unstructured SDKs, tools, and libraries do not work with the Unstructured API’s workflow operations:- The Unstructured JavaScript/TypeScript SDK
- Local single-file POST requests to the legacy Unstructured Partition Endpoint
- The Unstructured open source Python library
- The Unstructured Ingest CLI
- The Unstructured Ingest Python library
https://api.unstructuredapp.io/general/v0/general (the default legacy Unstructured Partition Endpoint URL).
