sap-business-document-processing


Namesap-business-document-processing JSON
Version 0.4.1 PyPI version JSON
download
home_pagehttps://github.com/sap/business-document-processing
SummaryPython client library for convenient usage of SAP Business Document Processing services
upload_time2024-05-07 11:22:02
maintainerNone
docs_urlNone
authorAlexander Bolshakov
requires_pythonNone
licenseapache-2.0
keywords sap business document processing classification information extraction machine learning
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <!--
SPDX-FileCopyrightText: 2020 2019-2020 SAP SE

SPDX-License-Identifier: Apache-2.0
-->

# Python Client Library for the SAP AI Business Services: Document Classification and Document Information Extraction

[![REUSE status](https://api.reuse.software/badge/github.com/SAP/business-document-processing)](https://api.reuse.software/info/github.com/SAP/business-document-processing)

This repository contains the [source code](https://github.com/SAP/business-document-processing/tree/main/sap_business_document_processing) of a Python client library to facilitate the use of the SAP AI Business Services: [Document Classification](https://help.sap.com/dc) and [Document Information Extraction](https://help.sap.com/dox). The client library provides two API Client classes that contain convenient methods to access these services and issue calls to the [Document Classification REST API](https://help.sap.com/viewer/ca60cd2ed44f4261a3ae500234c46f37/SHIP/en-US/c1045a561faf4ba0ae2b0e7713f5e6c4.html) and [Document Information Extraction REST API](https://help.sap.com/viewer/5fa7265b9ff64d73bac7cec61ee55ae6/SHIP/en-US/ded7d34e60f1422ba2e04e892a7f0e25.html) respectively. To use the library you need to [have access to SAP Business Technology Platform](https://www.sap.com/products/cloud-platform/get-started.html).

Check out the [**usage examples**](https://github.com/SAP/business-document-processing/tree/main/examples), they are very useful to get started with the services.

Have a look at [**API documentation**](https://github.com/SAP/business-document-processing/blob/main/API.md) in order to use the library.

### Notes for users of the sap-document-classification-client library
This library includes all the capabilities of the sap-document-classification-client, which will not be developed further. However, the code is still available [here](https://github.com/SAP/business-document-processing/tree/master).
If you want to switch to this library, you have to be aware of the following changes:

* The DCApiClient can now be imported directly from the top module via: ```from sap_business_document_processing import DCApiClient```
* The functions ```classifiy_documents```, ```upload_documents_to_dataset```, ```upload_documents_directory_to_dataset``` now return an iterator instead of a list. You can either analyze individual results using with ```result = next(iterator)``` within a try-catch block (e.g. to handle each failed document) or use ```results = list(iterator)``` to turn it to a list. The latter will raise an error if at least one document failed.
* The function ```get_datasets_info``` now returns a list which is the "dataset" part of the API response json. (You just need to delete the \["dataset"\] from the response to work with it as until now)
* The function ```get_classification_documents_info``` now returns a list which is the "results" part of the API response json.
* The function ```get_training_models_info``` now returns a list which is the "models" part of the API response json.
* The function ```get_deployed_models_info``` now returns a list which is the "deployments" part of the API response json.
* The library now raises the following custom exceptions:
    - **BDPApiException**: Base exception for all exceptions of this library. Raise when no other exception is applicable.
    - **BDPClientException**: Raised when an HTTP response with status code between 400 and 500 is returned. Usually means incorrect user input. (Replaces some HTTPErrors)
    - **BDPServerException**: Raised when an HTTP response with status code between 500 and 600 is returned. Usually means that the server had some internal error. (Replaces some HTTPErrors)
    - **BDPUnauthorizedException**: Raised when an HTTP response with status code 401 is returned. Usually means that a wrong OAuth credentials were provided.
    - **BDPFailedAsynchronousOperationException**: Raised when an asynchronous job failed during processing. (Replaces FailedCallException)
    - **BDPPollingTimeoutException**: Raised when an asynchronous job exceeds the set polling_max_attempts. (Replaces PollingTimeoutException)
* The function ```_poll_for_url``` now doesn`t expect an 'url' and 'payload' parameters, but 'path' and 'json' parameters instead.


## Requirements

This library requires properly setup [Python](https://www.python.org/downloads/) 3.6 (or higher version) environment.

## Download and Installation

This Python library should be consumed in the standard way by running

```pip install sap-business-document-processing```

or adding the library as a dependency of your code in `requirements.txt` file.

## Demo usage

Prerequisites:
* [Get a Free Account on SAP BTP Trial](https://developers.sap.com/tutorials/hcp-create-trial-account.html)
* [Create Service Instance for Document Classification with Trial Account](https://developers.sap.com/tutorials/cp-aibus-dc-service-instance.html)
* [Create Service Instance for Document Information Extraction](https://developers.sap.com/tutorials/cp-aibus-dox-service-instance.html)

#### Document Classification

To try out the Document classification service using the document classification client
library you can also run the two demo links below:
* Try out classification using default model [demo](https://mybinder.org/v2/gh/SAP/business-document-processing/main?filepath=examples%2Fdocument_classification_examples%2Fclassification_default_model.ipynb)
* Try out training and classification using custom model [demo](https://mybinder.org/v2/gh/SAP/business-document-processing/main?filepath=examples%2Fdocument_classification_examples%2Ftrain_and_evaluate_custom_model.ipynb) (requires an enterprise account, trial account is **not** sufficient)

#### Document Information Extraction

Try out the Document Information Extraction service with this [showcase](https://mybinder.org/v2/gh/SAP/business-document-processing/main?filepath=examples%2Fdocument_information_extraction_examples%2Finformation_extraction_showcase.ipynb)

- [Exercises](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises)
    - [Exercise 1 - Set up Document Information Extraction Service and UI](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-1---set-up-document-information-extraction-service-and-ui)
    - [Exercise 2 - Upload a document for extraction using UI application](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-2---upload-documents-for-extraction-using-ui-application)
    - [Exercise 3 - Visualize, correct extraction results and confirm document using UI application](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-3---visualize-correct-extraction-results-and-confirm-document-using-ui-application)
    - [Exercise 4 - Get Auth token to use Document Information Extraction Rest API](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-4---get-auth-token-to-use-document-information-extraction-rest-api)
    - [Exercise 5 - Get extraction results of document using Rest API](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-5---get-extraction-results-of-document-using-rest-api)
    - [Exercise 6 - Upload supplier Data for matching](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-6---upload-supplier-data-for-matching)
    - [Exercise 7 - Upload document through Rest API to enrich the extraction Results with supplier data](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-7---upload-document-through-rest-api-to-enrich-the-extraction-results-with-supplier-data)

## Known Issues

Please see the [issues section](https://github.com/SAP/business-document-processing/issues).

## How to obtain support

In case you would like to contribute to this project, ask any questions or get support, please open an issue containing the description of your question or planned contribution in GitHub and we will get in touch.

## Licensing

Please see our [LICENSE](https://github.com/SAP/business-document-processing/blob/main/LICENSE) for copyright and license information. Detailed information including third-party components and their licensing/copyright information is available via the [REUSE tool](https://api.reuse.software/info/github.com/SAP/business-document-processing).

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/sap/business-document-processing",
    "name": "sap-business-document-processing",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "SAP, business, document, processing, classification, information, extraction, machine learning",
    "author": "Alexander Bolshakov",
    "author_email": "alexander.bolshakov@sap.com",
    "download_url": "https://files.pythonhosted.org/packages/ef/16/52118abb327551b9b38805ae74a51c08167fb53ea4791dc2df9f40a5a646/sap_business_document_processing-0.4.1.tar.gz",
    "platform": null,
    "description": "<!--\nSPDX-FileCopyrightText: 2020 2019-2020 SAP SE\n\nSPDX-License-Identifier: Apache-2.0\n-->\n\n# Python Client Library for the SAP AI Business Services: Document Classification and Document Information Extraction\n\n[![REUSE status](https://api.reuse.software/badge/github.com/SAP/business-document-processing)](https://api.reuse.software/info/github.com/SAP/business-document-processing)\n\nThis repository contains the [source code](https://github.com/SAP/business-document-processing/tree/main/sap_business_document_processing) of a Python client library to facilitate the use of the SAP AI Business Services: [Document Classification](https://help.sap.com/dc) and [Document Information Extraction](https://help.sap.com/dox). The client library provides two API Client classes that contain convenient methods to access these services and issue calls to the [Document Classification REST API](https://help.sap.com/viewer/ca60cd2ed44f4261a3ae500234c46f37/SHIP/en-US/c1045a561faf4ba0ae2b0e7713f5e6c4.html) and [Document Information Extraction REST API](https://help.sap.com/viewer/5fa7265b9ff64d73bac7cec61ee55ae6/SHIP/en-US/ded7d34e60f1422ba2e04e892a7f0e25.html) respectively. To use the library you need to [have access to SAP Business Technology Platform](https://www.sap.com/products/cloud-platform/get-started.html).\n\nCheck out the [**usage examples**](https://github.com/SAP/business-document-processing/tree/main/examples), they are very useful to get started with the services.\n\nHave a look at [**API documentation**](https://github.com/SAP/business-document-processing/blob/main/API.md) in order to use the library.\n\n### Notes for users of the sap-document-classification-client library\nThis library includes all the capabilities of the sap-document-classification-client, which will not be developed further. However, the code is still available [here](https://github.com/SAP/business-document-processing/tree/master).\nIf you want to switch to this library, you have to be aware of the following changes:\n\n* The DCApiClient can now be imported directly from the top module via: ```from sap_business_document_processing import DCApiClient```\n* The functions ```classifiy_documents```, ```upload_documents_to_dataset```, ```upload_documents_directory_to_dataset``` now return an iterator instead of a list. You can either analyze individual results using with ```result = next(iterator)``` within a try-catch block (e.g. to handle each failed document) or use ```results = list(iterator)``` to turn it to a list. The latter will raise an error if at least one document failed.\n* The function ```get_datasets_info``` now returns a list which is the \"dataset\" part of the API response json. (You just need to delete the \\[\"dataset\"\\] from the response to work with it as until now)\n* The function ```get_classification_documents_info``` now returns a list which is the \"results\" part of the API response json.\n* The function ```get_training_models_info``` now returns a list which is the \"models\" part of the API response json.\n* The function ```get_deployed_models_info``` now returns a list which is the \"deployments\" part of the API response json.\n* The library now raises the following custom exceptions:\n    - **BDPApiException**: Base exception for all exceptions of this library. Raise when no other exception is applicable.\n    - **BDPClientException**: Raised when an HTTP response with status code between 400 and 500 is returned. Usually means incorrect user input. (Replaces some HTTPErrors)\n    - **BDPServerException**: Raised when an HTTP response with status code between 500 and 600 is returned. Usually means that the server had some internal error. (Replaces some HTTPErrors)\n    - **BDPUnauthorizedException**: Raised when an HTTP response with status code 401 is returned. Usually means that a wrong OAuth credentials were provided.\n    - **BDPFailedAsynchronousOperationException**: Raised when an asynchronous job failed during processing. (Replaces FailedCallException)\n    - **BDPPollingTimeoutException**: Raised when an asynchronous job exceeds the set polling_max_attempts. (Replaces PollingTimeoutException)\n* The function ```_poll_for_url``` now doesn`t expect an 'url' and 'payload' parameters, but 'path' and 'json' parameters instead.\n\n\n## Requirements\n\nThis library requires properly setup [Python](https://www.python.org/downloads/) 3.6 (or higher version) environment.\n\n## Download and Installation\n\nThis Python library should be consumed in the standard way by running\n\n```pip install sap-business-document-processing```\n\nor adding the library as a dependency of your code in `requirements.txt` file.\n\n## Demo usage\n\nPrerequisites:\n* [Get a Free Account on SAP BTP Trial](https://developers.sap.com/tutorials/hcp-create-trial-account.html)\n* [Create Service Instance for Document Classification with Trial Account](https://developers.sap.com/tutorials/cp-aibus-dc-service-instance.html)\n* [Create Service Instance for Document Information Extraction](https://developers.sap.com/tutorials/cp-aibus-dox-service-instance.html)\n\n#### Document Classification\n\nTo try out the Document classification service using the document classification client\nlibrary you can also run the two demo links below:\n* Try out classification using default model [demo](https://mybinder.org/v2/gh/SAP/business-document-processing/main?filepath=examples%2Fdocument_classification_examples%2Fclassification_default_model.ipynb)\n* Try out training and classification using custom model [demo](https://mybinder.org/v2/gh/SAP/business-document-processing/main?filepath=examples%2Fdocument_classification_examples%2Ftrain_and_evaluate_custom_model.ipynb) (requires an enterprise account, trial account is **not** sufficient)\n\n#### Document Information Extraction\n\nTry out the Document Information Extraction service with this [showcase](https://mybinder.org/v2/gh/SAP/business-document-processing/main?filepath=examples%2Fdocument_information_extraction_examples%2Finformation_extraction_showcase.ipynb)\n\n- [Exercises](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises)\n    - [Exercise 1 - Set up Document Information Extraction Service and UI](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-1---set-up-document-information-extraction-service-and-ui)\n    - [Exercise 2 - Upload a document for extraction using UI application](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-2---upload-documents-for-extraction-using-ui-application)\n    - [Exercise 3 - Visualize, correct extraction results and confirm document using UI application](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-3---visualize-correct-extraction-results-and-confirm-document-using-ui-application)\n    - [Exercise 4 - Get Auth token to use Document Information Extraction Rest API](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-4---get-auth-token-to-use-document-information-extraction-rest-api)\n    - [Exercise 5 - Get extraction results of document using Rest API](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-5---get-extraction-results-of-document-using-rest-api)\n    - [Exercise 6 - Upload supplier Data for matching](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-6---upload-supplier-data-for-matching)\n    - [Exercise 7 - Upload document through Rest API to enrich the extraction Results with supplier data](https://github.com/SAP/business-document-processing/tree/main/doc_inf_ext_exercises#exercise-7---upload-document-through-rest-api-to-enrich-the-extraction-results-with-supplier-data)\n\n## Known Issues\n\nPlease see the [issues section](https://github.com/SAP/business-document-processing/issues).\n\n## How to obtain support\n\nIn case you would like to contribute to this project, ask any questions or get support, please open an issue containing the description of your question or planned contribution in GitHub and we will get in touch.\n\n## Licensing\n\nPlease see our [LICENSE](https://github.com/SAP/business-document-processing/blob/main/LICENSE) for copyright and license information. Detailed information including third-party components and their licensing/copyright information is available via the [REUSE tool](https://api.reuse.software/info/github.com/SAP/business-document-processing).\n",
    "bugtrack_url": null,
    "license": "apache-2.0",
    "summary": "Python client library for convenient usage of SAP Business Document Processing services",
    "version": "0.4.1",
    "project_urls": {
        "Download": "https://pypi.org/project/sap-business-document-processing",
        "Homepage": "https://github.com/sap/business-document-processing"
    },
    "split_keywords": [
        "sap",
        " business",
        " document",
        " processing",
        " classification",
        " information",
        " extraction",
        " machine learning"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "1d8ac6026272b5ba1db023b0940d6777f489f23655ff9fe9a43e6d02c378174b",
                "md5": "5f0320e25dab7a1d6851aac5a28b8c61",
                "sha256": "41d2dd04eda8e74f7d119dd239b118ec80a77533bc14c3f7250221fbd8d1a216"
            },
            "downloads": -1,
            "filename": "sap_business_document_processing-0.4.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "5f0320e25dab7a1d6851aac5a28b8c61",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 35067,
            "upload_time": "2024-05-07T11:21:59",
            "upload_time_iso_8601": "2024-05-07T11:21:59.612743Z",
            "url": "https://files.pythonhosted.org/packages/1d/8a/c6026272b5ba1db023b0940d6777f489f23655ff9fe9a43e6d02c378174b/sap_business_document_processing-0.4.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ef1652118abb327551b9b38805ae74a51c08167fb53ea4791dc2df9f40a5a646",
                "md5": "f13239ea7cd3618cfe254f41c4b9fe25",
                "sha256": "34e8ac3ffe73ec02b6c960fa37649b7258160b29eeecae3c0be1ee010764a634"
            },
            "downloads": -1,
            "filename": "sap_business_document_processing-0.4.1.tar.gz",
            "has_sig": false,
            "md5_digest": "f13239ea7cd3618cfe254f41c4b9fe25",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 32347,
            "upload_time": "2024-05-07T11:22:02",
            "upload_time_iso_8601": "2024-05-07T11:22:02.391461Z",
            "url": "https://files.pythonhosted.org/packages/ef/16/52118abb327551b9b38805ae74a51c08167fb53ea4791dc2df9f40a5a646/sap_business_document_processing-0.4.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-07 11:22:02",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "sap",
    "github_project": "business-document-processing",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [],
    "lcname": "sap-business-document-processing"
}
        
Elapsed time: 0.23669s