splore sdk to interact with splore services
Project description
Splore Python SDK
The Splore Python SDK simplifies the process of interacting with the Splore document processing platform. Use it to upload files, process documents, and retrieve extracted data with minimal setup.
📌 Table of Contents
🚀 Features
- Agent Management: Create, update, retrieve, and delete agents.
- File Upload: Upload documents for processing.
- Extractions: Extract structured data from documents.
- AWS S3 Integration: Process files directly from S3.
- Task Monitoring: Track the progress of extraction jobs.
- Error Handling: Provides meaningful errors and retry mechanisms.
📥 Installation
Install the SDK via pip:
pip install splore-sdk
For optional example dependencies:
pip install splore-sdk[examples]
🏁 Getting Started
Prerequisites
- API Key and Base ID: Obtain these from the Splore console.
- Python 3.7+: Ensure Python is installed.
Quick Start Example
from splore_sdk import SploreSDK
from time import sleep
# Initialize SDK
sdk = SploreSDK(api_key="YOUR_API_KEY", base_id="YOUR_BASE_ID")
# Get all agents
agents = sdk.agents.get_agents()
agent_id = agents[0]["id"] # Adjust as needed
# Initialize agent
extraction_agent = sdk.init_agent(agent_id=agent_id)
upload_response = extraction_agent.file_uploader.upload_file(file_path="path/to/file.pdf")
file_id = upload_response.get("fileId")
print("File uploaded with ID:", file_id)
# Start extraction
extraction_agent.extractions.start(file_id=file_id)
# Monitor extraction status
while True:
status = extraction_agent.extractions.processing_status(file_id=file_id)
if status.get("fileProcessingStatus") == "COMPLETED":
break
sleep(10) # Wait before checking again
# Retrieve extracted data
extracted_data = extraction_agent.extractions.extracted_response(file_id=file_id)
print("Extracted Data:", extracted_data)
📦 Modules Overview
🔹 Agent Management
Manage agents for document processing.
Example Usage
from splore_sdk import SploreSDK
# Initialize SDK
sdk = SploreSDK(api_key="YOUR_API_KEY", base_id="YOUR_BASE_ID")
# Create an agent
agent_payload = {"name": "Test Agent", "config": {"key": "value"}}
create_response = sdk.create_agent(agent_payload)
print("Create Agent Response:", create_response)
# Get agent details
agent_id = create_response.get("id")
get_response = sdk.get_agents(agentId=agent_id)
print("Get Agent Response:", get_response)
# Get all agents
all_agents = sdk.get_agents()
print("All Agents:", all_agents)
# Update the agent
update_payload = {"name": "Updated Agent Name"}
update_response = sdk.update_agent(agent_payload=update_payload)
print("Update Agent Response:", update_response)
# Delete the agent
delete_response = sdk.delete_agents(agentId=agent_id)
print("Delete Agent Response:", delete_response)
🔹 Extractions
Handle document processing and extraction.
Example Usage
from splore_sdk import SploreSDK
# Initialize SDK
sdk = SploreSDK(api_key="YOUR_API_KEY", base_id="YOUR_BASE_ID")
# Initialize Agent for extraction
extraction_agent = sdk.init_agent(agent_id="YOUR_AGENT_ID")
# Basic extraction flow
extraction_agent.extract(file_path="absolute_file_path")
response = extraction_agent.extractions.all_extracted_response()
print(response)
# Upload file
with open("sample.pdf", "rb") as file:
file_response = extraction_agent.file_uploader.upload_file(file)
file_id = file_response.get("fileId")
print("File uploaded with ID:", file_id)
# Start extraction
start_response = extraction_agent.extractions.start(file_id=file_id)
print("Extraction started:", start_response)
# Check processing status
status_response = extraction_agent.extractions.processing_status(file_id=file_id)
print("Processing status:", status_response)
# Get extracted response
extracted_data = extraction_agent.extractions.extracted_response(file_id=file_id)
print("Extracted Data:", extracted_data)
🔹 File Upload
Upload files to Splore for processing.
Example Usage
from splore_sdk import SploreSDK
# Initialize SDK
sdk = SploreSDK(api_key="YOUR_API_KEY", base_id="YOUR_BASE_ID")
# Open and upload file
with open("path/to/your/file.pdf", "rb") as file:
response = sdk.file_uploader.upload_file(file_stream=file)
print("Upload Response:", response)
🔹 AWS Integration
Download files from AWS S3 for extraction.
Example Usage
from splore_sdk import SploreSDK
from examples.aws import download_from_s3
# Initialize SDK
sdk = SploreSDK(api_key="YOUR_API_KEY", base_id="YOUR_BASE_ID")
# Initialize extraction agent
extraction_agent = sdk.init_agent(agent_id="YOUR_AGENT_ID")
# Create a temporary file destination
file_ref = sdk.file_uploader.create_temp_file_destination()
s3_uri = "s3://abc/def/abc.pdf"
# Download file from S3
download_from_s3(s3_uri, file_ref)
# Start extraction
response = extraction_agent.extract(file_path=file_ref)
print(response)
⚙️ Advanced Usage
🔸 Polling Interval Configuration
Customize the polling interval for extraction status checks.
while True:
status = sdk.extractions.processing_status(file_id=file_id)
if status.get("fileProcessingStatus") == "COMPLETED":
break
sleep(5) # Set custom polling interval
🔸 Error Handling
Handle errors gracefully for better debugging.
try:
sdk.extractions.upload_file("path/to/file.pdf")
except Exception as e:
print("Error uploading file:", str(e))
❓ FAQ
1️⃣ How do I get an API Key?
Sign up on the Splore console and navigate to the API section to generate a key.
2️⃣ Can I use this SDK asynchronously?
Asynchronous support will be added in a future release.
3️⃣ Which file formats are supported?
Currently, only PDF files are supported.
🔗 Support
For any questions or issues, please:
- Open a ticket on GitHub Issues
- Email us at support@splore.com
📜 License
This SDK is licensed under the MIT License. See LICENSE for details.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file splore_sdk-0.1.12.tar.gz.
File metadata
- Download URL: splore_sdk-0.1.12.tar.gz
- Upload date:
- Size: 11.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.21.0 CPython/3.13.1 Darwin/23.5.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
41744c715c4ee78a6a5462c7d7f7cd56f6911fac2303832045b4e059b816273f
|
|
| MD5 |
46d394e7865bdedf74f4f8ad1fd3cbf5
|
|
| BLAKE2b-256 |
9af3d8ce7545bbfcf0897e6af9c7553078e85cf148a7141ca8bbc472341926cb
|
File details
Details for the file splore_sdk-0.1.12-py3-none-any.whl.
File metadata
- Download URL: splore_sdk-0.1.12-py3-none-any.whl
- Upload date:
- Size: 16.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.21.0 CPython/3.13.1 Darwin/23.5.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3bf6e02839b27bdff642ad89b9f6e7ef1b4dca5f5aa717fbc1616a67d71a0de4
|
|
| MD5 |
f264917c993534fb03d5ed7a09d64a2d
|
|
| BLAKE2b-256 |
ef68f587b10ba4afb8380761307575d4788c4e3c41548ee02ee72cff51c25343
|