A Python client library for Nutrient Document Web Services (DWS) API. This library provides a fully async, type-safe, and ergonomic interface for document processing operations including conversion, merging, compression, watermarking, OCR, and text extraction.
Note: This package is published as
nutrient-dws
on PyPI. The package provides full type support and is designed for async Python environments (Python 3.10+).
- π Powerful document processing: Convert, OCR, edit, compress, watermark, redact, and digitally sign documents
- π€ LLM friendly: Built-in support for popular Coding Agents (Claude Code, GitHub Copilot, JetBrains Junie, Cursor, Windsurf) with auto-generated rules
- π 100% mapping with DWS Processor API: Complete coverage of all Nutrient DWS Processor API capabilities
- π οΈ Convenient functions with sane defaults: Simple interfaces for common operations with smart default settings
- βοΈ Chainable operations: Build complex document workflows with intuitive method chaining
- π Fully async: Built from the ground up with async/await support for optimal performance
- π Flexible authentication and security: Support for API keys and async token providers with secure handling
- β Highly tested: Comprehensive test suite ensuring reliability and stability
- π Type-safe: Full type annotations with comprehensive type definitions
- π Pythonic: Follows Python conventions and best practices
pip install nutrient-dws
This package has built-in support with popular coding agents like Claude Code, GitHub Copilot, Cursor, and Windsurf by exposing scripts that will inject rules instructing the coding agents on how to use the package. This ensures that the coding agent doesn't hallucinate documentation, as well as making full use of all the features offered in Nutrient DWS Python Client.
# Adding code rule to Claude Code dws-add-claude-code-rule # Adding code rule to GitHub Copilot dws-add-github-copilot-rule # Adding code rule to Junie (Jetbrains) dws-add-junie-rule # Adding code rule to Cursor dws-add-cursor-rule # Adding code rule to Windsurf dws-add-windsurf-rule
The documentation for Nutrient DWS Python Client is also available on Context7
from nutrient_dws import NutrientClient client = NutrientClient(api_key='your_api_key')
The client provides numerous async methods for document processing:
import asyncio from nutrient_dws import NutrientClient async def main(): client = NutrientClient(api_key='your_api_key') # Convert a document pdf_result = await client.convert('document.docx', 'pdf') # Extract text text_result = await client.extract_text('document.pdf') # Add a watermark watermarked_doc = await client.watermark_text('document.pdf', 'CONFIDENTIAL') # Merge multiple documents merged_pdf = await client.merge(['doc1.pdf', 'doc2.pdf', 'doc3.pdf']) asyncio.run(main())
For a complete list of available methods with examples, see the Methods Documentation.
The client also provides a fluent builder pattern with staged interfaces to create document processing workflows:
from nutrient_dws.builder.constant import BuildActions async def main(): client = NutrientClient(api_key='your_api_key') result = await (client .workflow() .add_file_part('document.pdf') .add_file_part('appendix.pdf') .apply_action(BuildActions.watermark_text('CONFIDENTIAL', { 'opacity': 0.5, 'fontSize': 48 })) .output_pdf({ 'optimize': { 'mrcCompression': True, 'imageOptimizationQuality': 2 } }) .execute()) asyncio.run(main())
The workflow system follows a staged approach:
- Add document parts (files, HTML, pages)
- Apply actions (optional)
- Set output format
- Execute or perform a dry run
For detailed information about the workflow system, including examples and best practices, see the Workflow Documentation.
The library provides a comprehensive error hierarchy:
from nutrient_dws import ( NutrientClient, NutrientError, ValidationError, APIError, AuthenticationError, NetworkError ) async def main(): client = NutrientClient(api_key='your_api_key') try: result = await client.convert('file.docx', 'pdf') except ValidationError as error: # Invalid input parameters print(f'Invalid input: {error.message} - Details: {error.details}') except AuthenticationError as error: # Authentication failed print(f'Auth error: {error.message} - Status: {error.status_code}') except APIError as error: # API returned an error print(f'API error: {error.message} - Status: {error.status_code} - Details: {error.details}') except NetworkError as error: # Network request failed print(f'Network error: {error.message} - Details: {error.details}') asyncio.run(main())
The library includes comprehensive unit and integration tests:
# Run all tests python -m pytest # Run with coverage report python -m pytest --cov=nutrient_dws --cov-report=html # Run only unit tests python -m pytest tests/unit/ # Run integration tests (requires API key) NUTRIENT_API_KEY=your_key python -m pytest tests/test_integration.py
The library maintains high test coverage across all API methods, including:
- Unit tests for all public methods
- Integration tests for real API interactions
- Type checking with mypy
For development, install the package in development mode:
# Clone the repository git clone https://github.com/PSPDFKit/nutrient-dws-client-python.git cd nutrient-dws-client-python # Install in development mode pip install -e ".[dev]" # Run type checking mypy src/ # Run linting ruff check src/ # Run formatting ruff format src/
We welcome contributions to improve the library! Please follow our development standards to ensure code quality and maintainability.
Quick start for contributors:
- Clone and setup the repository
- Make changes following atomic commit practices
- Use conventional commits for clear change history
- Include appropriate tests for new features
- Ensure type checking passes with mypy
- Follow Python code style with ruff
For detailed contribution guidelines, see the Contributing Guide.
src/ βββ nutrient_dws/ β βββ builder/ # Builder classes and constants β βββ generated/ # Generated type definitions β βββ types/ # Type definitions β βββ client.py # Main NutrientClient class β βββ errors.py # Error classes β βββ http.py # HTTP layer β βββ inputs.py # Input handling β βββ workflow.py # Workflow factory β βββ __init__.py # Public exports βββ nutrient_dws_scripts/ # CLI scripts for coding agents βββ tests/ # Test files
This library supports Python 3.10 and higher. The async-first design requires modern Python features for optimal performance and type safety.
This project is licensed under the MIT License - see the LICENSE file for details.
For issues and feature requests, please use the GitHub issue tracker.
For questions about the Nutrient DWS Processor API, refer to the official documentation.