# Docugami Loader
```bash
pip install llama-index-readers-docugami
```
This loader takes in IDs of PDF, DOCX or DOC files processed by [Docugami](https://docugami.com) and returns nodes in a Document XML Knowledge Graph for each document. This is a rich representation that includes the semantic and structural characteristics of various chunks in the document as an XML tree. Entire sets of documents are processed, resulting in forests of XML semantic trees.
## Pre-requisites
1. Create a Docugami workspace: [http://www.docugami.com](http://www.docugami.com) (free trials available)
2. Add your documents (PDF, DOCX or DOC) and allow Docugami to ingest and cluster them into sets of similar documents, e.g. NDAs, Lease Agreements, and Service Agreements. There is no fixed set of document types supported by the system, the clusters created depend on your particular documents, and you can [change the docset assignments](https://help.docugami.com/home/working-with-the-doc-sets-view) later.
3. Create an access token via the Developer Playground for your workspace. Detailed instructions: [https://help.docugami.com/home/docugami-api](https://help.docugami.com/home/docugami-api)
4. Explore the Docugami API at [https://api-docs.docugami.com](https://api-docs.docugami.com) to get a list of your processed docset IDs, or just the document IDs for a particular docset.
## Usage
To use this loader, you simply need to pass in a Docugami Doc Set ID, and optionally an array of Document IDs (by default, all documents in the Doc Set are loaded).
```python
from llama_index.readers.docugami import DocugamiReader
docset_id = "tjwrr2ekqkc3"
document_ids = ["ui7pkriyckwi", "1be3o7ch10iy"]
loader = DocugamiReader()
documents = loader.load_data(docset_id=docset_id, document_ids=document_ids)
```
This loader is designed to be used as a way to load data into [LlamaIndex](https://github.com/run-llama/llama_index/).
See more information about how to use Docugami with LangChain in the [LangChain docs](https://python.langchain.com/docs/ecosystem/integrations/docugami).
# Advantages vs Other Chunking Techniques
Appropriate chunking of your documents is critical for retrieval from documents. Many chunking techniques exist, including simple ones that rely on whitespace and recursive chunk splitting based on character length. Docugami offers a different approach:
1. **Intelligent Chunking:** Docugami breaks down every document into a hierarchical semantic XML tree of chunks of varying sizes, from single words or numerical values to entire sections. These chunks follow the semantic contours of the document, providing a more meaningful representation than arbitrary length or simple whitespace-based chunking.
2. **Structured Representation:** In addition, the XML tree indicates the structural contours of every document, using attributes denoting headings, paragraphs, lists, tables, and other common elements, and does that consistently across all supported document formats, such as scanned PDFs or DOCX files. It appropriately handles long-form document characteristics like page headers/footers or multi-column flows for clean text extraction.
3. **Semantic Annotations:** Chunks are annotated with semantic tags that are coherent across the document set, facilitating consistent hierarchical queries across multiple documents, even if they are written and formatted differently. For example, in set of lease agreements, you can easily identify key provisions like the Landlord, Tenant, or Renewal Date, as well as more complex information such as the wording of any sub-lease provision or whether a specific jurisdiction has an exception section within a Termination Clause.
4. **Additional Metadata:** Chunks are also annotated with additional metadata, if a user has been using Docugami. This additional metadata can be used for high-accuracy Document QA without context window restrictions. See detailed code walk-through in [this notebook](https://github.com/run-llama/llama_index/blob/main/llama-index-integrations/readers/llama-index-readers-docugami/examples/docugami.ipynb).
Raw data
{
"_id": null,
"home_page": null,
"name": "llama-index-readers-docugami",
"maintainer": "tjaffri",
"docs_url": null,
"requires_python": "<4.0,>=3.8.1",
"maintainer_email": null,
"keywords": "doc, docugami, docx, pdf, xml",
"author": "Your Name",
"author_email": "you@example.com",
"download_url": "https://files.pythonhosted.org/packages/7e/78/ddd277d53239503a133a8d8800dbffaffc07ac695bb54d04a5e77dee5b22/llama_index_readers_docugami-0.2.0.tar.gz",
"platform": null,
"description": "# Docugami Loader\n\n```bash\npip install llama-index-readers-docugami\n```\n\nThis loader takes in IDs of PDF, DOCX or DOC files processed by [Docugami](https://docugami.com) and returns nodes in a Document XML Knowledge Graph for each document. This is a rich representation that includes the semantic and structural characteristics of various chunks in the document as an XML tree. Entire sets of documents are processed, resulting in forests of XML semantic trees.\n\n## Pre-requisites\n\n1. Create a Docugami workspace: [http://www.docugami.com](http://www.docugami.com) (free trials available)\n2. Add your documents (PDF, DOCX or DOC) and allow Docugami to ingest and cluster them into sets of similar documents, e.g. NDAs, Lease Agreements, and Service Agreements. There is no fixed set of document types supported by the system, the clusters created depend on your particular documents, and you can [change the docset assignments](https://help.docugami.com/home/working-with-the-doc-sets-view) later.\n3. Create an access token via the Developer Playground for your workspace. Detailed instructions: [https://help.docugami.com/home/docugami-api](https://help.docugami.com/home/docugami-api)\n4. Explore the Docugami API at [https://api-docs.docugami.com](https://api-docs.docugami.com) to get a list of your processed docset IDs, or just the document IDs for a particular docset.\n\n## Usage\n\nTo use this loader, you simply need to pass in a Docugami Doc Set ID, and optionally an array of Document IDs (by default, all documents in the Doc Set are loaded).\n\n```python\nfrom llama_index.readers.docugami import DocugamiReader\n\ndocset_id = \"tjwrr2ekqkc3\"\ndocument_ids = [\"ui7pkriyckwi\", \"1be3o7ch10iy\"]\n\nloader = DocugamiReader()\ndocuments = loader.load_data(docset_id=docset_id, document_ids=document_ids)\n```\n\nThis loader is designed to be used as a way to load data into [LlamaIndex](https://github.com/run-llama/llama_index/).\n\nSee more information about how to use Docugami with LangChain in the [LangChain docs](https://python.langchain.com/docs/ecosystem/integrations/docugami).\n\n# Advantages vs Other Chunking Techniques\n\nAppropriate chunking of your documents is critical for retrieval from documents. Many chunking techniques exist, including simple ones that rely on whitespace and recursive chunk splitting based on character length. Docugami offers a different approach:\n\n1. **Intelligent Chunking:** Docugami breaks down every document into a hierarchical semantic XML tree of chunks of varying sizes, from single words or numerical values to entire sections. These chunks follow the semantic contours of the document, providing a more meaningful representation than arbitrary length or simple whitespace-based chunking.\n2. **Structured Representation:** In addition, the XML tree indicates the structural contours of every document, using attributes denoting headings, paragraphs, lists, tables, and other common elements, and does that consistently across all supported document formats, such as scanned PDFs or DOCX files. It appropriately handles long-form document characteristics like page headers/footers or multi-column flows for clean text extraction.\n3. **Semantic Annotations:** Chunks are annotated with semantic tags that are coherent across the document set, facilitating consistent hierarchical queries across multiple documents, even if they are written and formatted differently. For example, in set of lease agreements, you can easily identify key provisions like the Landlord, Tenant, or Renewal Date, as well as more complex information such as the wording of any sub-lease provision or whether a specific jurisdiction has an exception section within a Termination Clause.\n4. **Additional Metadata:** Chunks are also annotated with additional metadata, if a user has been using Docugami. This additional metadata can be used for high-accuracy Document QA without context window restrictions. See detailed code walk-through in [this notebook](https://github.com/run-llama/llama_index/blob/main/llama-index-integrations/readers/llama-index-readers-docugami/examples/docugami.ipynb).\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "llama-index readers docugami integration",
"version": "0.2.0",
"project_urls": null,
"split_keywords": [
"doc",
" docugami",
" docx",
" pdf",
" xml"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "9c4ccc852a8e47e25168677ef3959e822f7adaa3217e7ec07cde164892de7390",
"md5": "e170575fe5b7c4ea974a1a327cd46ac7",
"sha256": "cbf2e691a060aebad5bd9be5999cd7ef87c3c2a33289cbda5fb0765e50e7ccce"
},
"downloads": -1,
"filename": "llama_index_readers_docugami-0.2.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "e170575fe5b7c4ea974a1a327cd46ac7",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.8.1",
"size": 7095,
"upload_time": "2024-08-22T03:12:41",
"upload_time_iso_8601": "2024-08-22T03:12:41.785232Z",
"url": "https://files.pythonhosted.org/packages/9c/4c/cc852a8e47e25168677ef3959e822f7adaa3217e7ec07cde164892de7390/llama_index_readers_docugami-0.2.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "7e78ddd277d53239503a133a8d8800dbffaffc07ac695bb54d04a5e77dee5b22",
"md5": "3d62853ecfeb4b886cce69563d98e382",
"sha256": "d92beb70733b4d6bab48393e4961a704691c5d455b9a5d87179417dffe35ed1c"
},
"downloads": -1,
"filename": "llama_index_readers_docugami-0.2.0.tar.gz",
"has_sig": false,
"md5_digest": "3d62853ecfeb4b886cce69563d98e382",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.8.1",
"size": 6902,
"upload_time": "2024-08-22T03:12:43",
"upload_time_iso_8601": "2024-08-22T03:12:43.063835Z",
"url": "https://files.pythonhosted.org/packages/7e/78/ddd277d53239503a133a8d8800dbffaffc07ac695bb54d04a5e77dee5b22/llama_index_readers_docugami-0.2.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-08-22 03:12:43",
"github": false,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"lcname": "llama-index-readers-docugami"
}