-
Notifications
You must be signed in to change notification settings - Fork 15.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Refactoring all PDF loader and parser
- Loading branch information
Showing
20 changed files
with
10,538 additions
and
1,830 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
2,084 changes: 2,032 additions & 52 deletions
2,084
docs/docs/integrations/document_loaders/pdfminer.ipynb
Large diffs are not rendered by default.
Oops, something went wrong.
1,104 changes: 1,058 additions & 46 deletions
1,104
docs/docs/integrations/document_loaders/pdfplumber.ipynb
Large diffs are not rendered by default.
Oops, something went wrong.
1,140 changes: 1,099 additions & 41 deletions
1,140
docs/docs/integrations/document_loaders/pymupdf.ipynb
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,7 +4,11 @@ | |
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# PyPDFDirectoryLoader\n", | ||
"# PyPDFDirectoryLoader (Deprecated)\n", | ||
"\n", | ||
"Note: This loader is deprecated. Please use [GenericLoader](https://python.langchain.com/docs/how_to/document_loader_custom/#overview) instead.\n", | ||
"\n", | ||
" \n", | ||
"\n", | ||
"This loader loads all PDF files from a specific directory.\n", | ||
"\n", | ||
|
@@ -36,13 +40,18 @@ | |
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"metadata": { | ||
"ExecuteTime": { | ||
"end_time": "2024-12-13T14:39:11.095053Z", | ||
"start_time": "2024-12-13T14:39:11.081014Z" | ||
} | ||
}, | ||
"source": [ | ||
"# os.environ[\"LANGSMITH_API_KEY\"] = getpass.getpass(\"Enter your LangSmith API key: \")\n", | ||
"# os.environ[\"LANGSMITH_TRACING\"] = \"true\"" | ||
] | ||
], | ||
"outputs": [], | ||
"execution_count": 7 | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
|
@@ -55,12 +64,24 @@ | |
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"%pip install -qU langchain_community" | ||
] | ||
"metadata": { | ||
"ExecuteTime": { | ||
"end_time": "2024-12-13T14:39:24.982355Z", | ||
"start_time": "2024-12-13T14:39:11.169779Z" | ||
} | ||
}, | ||
"source": "%pip install -qU langchain_community pypdf pillow", | ||
"outputs": [ | ||
{ | ||
"name": "stdout", | ||
"output_type": "stream", | ||
"text": [ | ||
"Note: you may need to restart the kernel to use updated packages.\n", | ||
"Note: you may need to restart the kernel to use updated packages.\n" | ||
] | ||
} | ||
], | ||
"execution_count": 8 | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
|
@@ -73,17 +94,22 @@ | |
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": 1, | ||
"metadata": {}, | ||
"outputs": [], | ||
"metadata": { | ||
"ExecuteTime": { | ||
"end_time": "2024-12-13T14:39:25.087581Z", | ||
"start_time": "2024-12-13T14:39:25.071818Z" | ||
} | ||
}, | ||
"source": [ | ||
"from langchain_community.document_loaders import PyPDFDirectoryLoader\n", | ||
"\n", | ||
"directory_path = (\n", | ||
" \"../../docs/integrations/document_loaders/example_data/layout-parser-paper.pdf\"\n", | ||
")\n", | ||
"loader = PyPDFDirectoryLoader(\"example_data/\")" | ||
] | ||
], | ||
"outputs": [], | ||
"execution_count": 9 | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
|
@@ -94,41 +120,51 @@ | |
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": 2, | ||
"metadata": {}, | ||
"metadata": { | ||
"ExecuteTime": { | ||
"end_time": "2024-12-13T14:39:26.846482Z", | ||
"start_time": "2024-12-13T14:39:25.235776Z" | ||
} | ||
}, | ||
"source": [ | ||
"docs = loader.load()\n", | ||
"docs[0]" | ||
], | ||
"outputs": [ | ||
{ | ||
"data": { | ||
"text/plain": [ | ||
"Document(metadata={'source': 'example_data/layout-parser-paper.pdf', 'page': 0}, page_content='LayoutParser : A Unified Toolkit for Deep\\nLearning Based Document Image Analysis\\nZejiang Shen1( \\x00), Ruochen Zhang2, Melissa Dell3, Benjamin Charles Germain\\nLee4, Jacob Carlson3, and Weining Li5\\n1Allen Institute for AI\\[email protected]\\n2Brown University\\nruochen [email protected]\\n3Harvard University\\n{melissadell,jacob carlson }@fas.harvard.edu\\n4University of Washington\\[email protected]\\n5University of Waterloo\\[email protected]\\nAbstract. Recent advances in document image analysis (DIA) have been\\nprimarily driven by the application of neural networks. Ideally, research\\noutcomes could be easily deployed in production and extended for further\\ninvestigation. However, various factors like loosely organized codebases\\nand sophisticated model configurations complicate the easy reuse of im-\\nportant innovations by a wide audience. Though there have been on-going\\nefforts to improve reusability and simplify deep learning (DL) model\\ndevelopment in disciplines like natural language processing and computer\\nvision, none of them are optimized for challenges in the domain of DIA.\\nThis represents a major gap in the existing toolkit, as DIA is central to\\nacademic research across a wide range of disciplines in the social sciences\\nand humanities. This paper introduces LayoutParser , an open-source\\nlibrary for streamlining the usage of DL in DIA research and applica-\\ntions. The core LayoutParser library comes with a set of simple and\\nintuitive interfaces for applying and customizing DL models for layout de-\\ntection, character recognition, and many other document processing tasks.\\nTo promote extensibility, LayoutParser also incorporates a community\\nplatform for sharing both pre-trained models and full document digiti-\\nzation pipelines. We demonstrate that LayoutParser is helpful for both\\nlightweight and large-scale digitization pipelines in real-word use cases.\\nThe library is publicly available at https://layout-parser.github.io .\\nKeywords: Document Image Analysis ·Deep Learning ·Layout Analysis\\n·Character Recognition ·Open Source library ·Toolkit.\\n1 Introduction\\nDeep Learning(DL)-based approaches are the state-of-the-art for a wide range of\\ndocument image analysis (DIA) tasks including document image classification [ 11,arXiv:2103.15348v2 [cs.CV] 21 Jun 2021')" | ||
"Document(metadata={'author': '', 'creationdate': '2021-06-22T01:27:10+00:00', 'creator': 'LaTeX with hyperref', 'keywords': '', 'moddate': '2021-06-22T01:27:10+00:00', 'ptex.fullbanner': 'This is pdfTeX, Version 3.14159265-2.6-1.40.21 (TeX Live 2020) kpathsea version 6.3.2', 'producer': 'pdfTeX-1.40.21', 'subject': '', 'title': '', 'trapped': '/False', 'source': 'example_data/layout-parser-paper.pdf', 'total_pages': 16, 'page': 0}, page_content='LayoutParser: A Unified Toolkit for Deep\\nLearning Based Document Image Analysis\\nZejiang Shen1 (\\x00 ), Ruochen Zhang2, Melissa Dell3, Benjamin Charles Germain\\nLee4, Jacob Carlson3, and Weining Li5\\n1 Allen Institute for AI\\[email protected]\\n2 Brown University\\nruochen [email protected]\\n3 Harvard University\\n{melissadell,jacob carlson}@fas.harvard.edu\\n4 University of Washington\\[email protected]\\n5 University of Waterloo\\[email protected]\\nAbstract. Recent advances in document image analysis (DIA) have been\\nprimarily driven by the application of neural networks. Ideally, research\\noutcomes could be easily deployed in production and extended for further\\ninvestigation. However, various factors like loosely organized codebases\\nand sophisticated model configurations complicate the easy reuse of im-\\nportant innovations by a wide audience. Though there have been on-going\\nefforts to improve reusability and simplify deep learning (DL) model\\ndevelopment in disciplines like natural language processing and computer\\nvision, none of them are optimized for challenges in the domain of DIA.\\nThis represents a major gap in the existing toolkit, as DIA is central to\\nacademic research across a wide range of disciplines in the social sciences\\nand humanities. This paper introduces LayoutParser, an open-source\\nlibrary for streamlining the usage of DL in DIA research and applica-\\ntions. The core LayoutParser library comes with a set of simple and\\nintuitive interfaces for applying and customizing DL models for layout de-\\ntection, character recognition, and many other document processing tasks.\\nTo promote extensibility, LayoutParser also incorporates a community\\nplatform for sharing both pre-trained models and full document digiti-\\nzation pipelines. We demonstrate that LayoutParser is helpful for both\\nlightweight and large-scale digitization pipelines in real-word use cases.\\nThe library is publicly available at https://layout-parser.github.io.\\nKeywords: Document Image Analysis · Deep Learning · Layout Analysis\\n· Character Recognition · Open Source library · Toolkit.\\n1 Introduction\\nDeep Learning(DL)-based approaches are the state-of-the-art for a wide range of\\ndocument image analysis (DIA) tasks including document image classification [11,\\narXiv:2103.15348v2 [cs.CV] 21 Jun 2021')" | ||
] | ||
}, | ||
"execution_count": 2, | ||
"execution_count": 10, | ||
"metadata": {}, | ||
"output_type": "execute_result" | ||
} | ||
], | ||
"source": [ | ||
"docs = loader.load()\n", | ||
"docs[0]" | ||
] | ||
"execution_count": 10 | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": 3, | ||
"metadata": {}, | ||
"metadata": { | ||
"ExecuteTime": { | ||
"end_time": "2024-12-13T14:39:26.908137Z", | ||
"start_time": "2024-12-13T14:39:26.898245Z" | ||
} | ||
}, | ||
"source": [ | ||
"print(docs[0].metadata)" | ||
], | ||
"outputs": [ | ||
{ | ||
"name": "stdout", | ||
"output_type": "stream", | ||
"text": [ | ||
"{'source': 'example_data/layout-parser-paper.pdf', 'page': 0}\n" | ||
"{'author': '', 'creationdate': '2021-06-22T01:27:10+00:00', 'creator': 'LaTeX with hyperref', 'keywords': '', 'moddate': '2021-06-22T01:27:10+00:00', 'ptex.fullbanner': 'This is pdfTeX, Version 3.14159265-2.6-1.40.21 (TeX Live 2020) kpathsea version 6.3.2', 'producer': 'pdfTeX-1.40.21', 'subject': '', 'title': '', 'trapped': '/False', 'source': 'example_data/layout-parser-paper.pdf', 'total_pages': 16, 'page': 0}\n" | ||
] | ||
} | ||
], | ||
"source": [ | ||
"print(docs[0].metadata)" | ||
] | ||
"execution_count": 11 | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
|
@@ -139,9 +175,12 @@ | |
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": 4, | ||
"metadata": {}, | ||
"outputs": [], | ||
"metadata": { | ||
"ExecuteTime": { | ||
"end_time": "2024-12-13T14:39:28.341129Z", | ||
"start_time": "2024-12-13T14:39:26.999576Z" | ||
} | ||
}, | ||
"source": [ | ||
"page = []\n", | ||
"for doc in loader.lazy_load():\n", | ||
|
@@ -151,7 +190,9 @@ | |
" # index.upsert(page)\n", | ||
"\n", | ||
" page = []" | ||
] | ||
], | ||
"outputs": [], | ||
"execution_count": 12 | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
|
Oops, something went wrong.