Grobid parser for Scientific Articles from PDF (#6729)
### Scientific Article PDF Parsing via Grobid
`Description:`
This change adds the GrobidParser class, which uses the Grobid library
to parse scientific articles into a universal XML format containing the
article title, references, sections, section text etc. The GrobidParser
uses a local Grobid server to return PDFs document as XML and parses the
XML to optionally produce documents of individual sentences or of whole
paragraphs. Metadata includes the text, paragraph number, pdf relative
bboxes, pages (text may overlap over two pages), section title
(Introduction, Methodology etc), section_number (i.e 1.1, 2.3), the
title of the paper and finally the file path.
Grobid parsing is useful beyond standard pdf parsing as it accurately
outputs sections and paragraphs within them. This allows for
post-fitering of results for specific sections i.e. limiting results to
the methodology section or results. While sections are split via
headings, ideally they could be classified specifically into
introduction, methodology, results, discussion, conclusion. I'm
currently experimenting with chatgpt-3.5 for this function, which could
later be implemented as a textsplitter.
`Dependencies:`
For use, the grobid repo must be cloned and Java must be installed, for
colab this is:
```
!apt-get install -y openjdk-11-jdk -q
!update-alternatives --set java /usr/lib/jvm/java-11-openjdk-amd64/bin/java
!git clone https://github.com/kermitt2/grobid.git
os.environ["JAVA_HOME"] = "/usr/lib/jvm/java-11-openjdk-amd64"
os.chdir('grobid')
!./gradlew clean install
```
Once installed the server is ran on localhost:8070 via
```
get_ipython().system_raw('nohup ./gradlew run > grobid.log 2>&1 &')
```
@rlancemartin, @eyurtsev
Twitter Handle: @Corranmac
Grobid Demo Notebook is
[here](https://colab.research.google.com/drive/1X-St_mQRmmm8YWtct_tcJNtoktbdGBmd?usp=sharing).
---------
Co-authored-by: rlm <pexpresss31@gmail.com>
2023-06-29 21:29:29 +00:00
|
|
|
# Grobid
|
|
|
|
|
|
|
|
This page covers how to use the Grobid to parse articles for LangChain.
|
2023-07-12 20:20:08 +00:00
|
|
|
It is separated into two parts: installation and running the server
|
Grobid parser for Scientific Articles from PDF (#6729)
### Scientific Article PDF Parsing via Grobid
`Description:`
This change adds the GrobidParser class, which uses the Grobid library
to parse scientific articles into a universal XML format containing the
article title, references, sections, section text etc. The GrobidParser
uses a local Grobid server to return PDFs document as XML and parses the
XML to optionally produce documents of individual sentences or of whole
paragraphs. Metadata includes the text, paragraph number, pdf relative
bboxes, pages (text may overlap over two pages), section title
(Introduction, Methodology etc), section_number (i.e 1.1, 2.3), the
title of the paper and finally the file path.
Grobid parsing is useful beyond standard pdf parsing as it accurately
outputs sections and paragraphs within them. This allows for
post-fitering of results for specific sections i.e. limiting results to
the methodology section or results. While sections are split via
headings, ideally they could be classified specifically into
introduction, methodology, results, discussion, conclusion. I'm
currently experimenting with chatgpt-3.5 for this function, which could
later be implemented as a textsplitter.
`Dependencies:`
For use, the grobid repo must be cloned and Java must be installed, for
colab this is:
```
!apt-get install -y openjdk-11-jdk -q
!update-alternatives --set java /usr/lib/jvm/java-11-openjdk-amd64/bin/java
!git clone https://github.com/kermitt2/grobid.git
os.environ["JAVA_HOME"] = "/usr/lib/jvm/java-11-openjdk-amd64"
os.chdir('grobid')
!./gradlew clean install
```
Once installed the server is ran on localhost:8070 via
```
get_ipython().system_raw('nohup ./gradlew run > grobid.log 2>&1 &')
```
@rlancemartin, @eyurtsev
Twitter Handle: @Corranmac
Grobid Demo Notebook is
[here](https://colab.research.google.com/drive/1X-St_mQRmmm8YWtct_tcJNtoktbdGBmd?usp=sharing).
---------
Co-authored-by: rlm <pexpresss31@gmail.com>
2023-06-29 21:29:29 +00:00
|
|
|
|
|
|
|
## Installation and Setup
|
|
|
|
#Ensure You have Java installed
|
|
|
|
!apt-get install -y openjdk-11-jdk -q
|
|
|
|
!update-alternatives --set java /usr/lib/jvm/java-11-openjdk-amd64/bin/java
|
|
|
|
|
|
|
|
#Clone and install the Grobid Repo
|
|
|
|
import os
|
|
|
|
!git clone https://github.com/kermitt2/grobid.git
|
|
|
|
os.environ["JAVA_HOME"] = "/usr/lib/jvm/java-11-openjdk-amd64"
|
|
|
|
os.chdir('grobid')
|
|
|
|
!./gradlew clean install
|
|
|
|
|
|
|
|
#Run the server,
|
|
|
|
get_ipython().system_raw('nohup ./gradlew run > grobid.log 2>&1 &')
|
|
|
|
|
|
|
|
You can now use the GrobidParser to produce documents
|
|
|
|
```python
|
|
|
|
from langchain.document_loaders.parsers import GrobidParser
|
|
|
|
from langchain.document_loaders.generic import GenericLoader
|
|
|
|
|
|
|
|
#Produce chunks from article paragraphs
|
|
|
|
loader = GenericLoader.from_filesystem(
|
|
|
|
"/Users/31treehaus/Desktop/Papers/",
|
|
|
|
glob="*",
|
|
|
|
suffixes=[".pdf"],
|
|
|
|
parser= GrobidParser(segment_sentences=False)
|
|
|
|
)
|
|
|
|
docs = loader.load()
|
|
|
|
|
|
|
|
#Produce chunks from article sentences
|
|
|
|
loader = GenericLoader.from_filesystem(
|
|
|
|
"/Users/31treehaus/Desktop/Papers/",
|
|
|
|
glob="*",
|
|
|
|
suffixes=[".pdf"],
|
|
|
|
parser= GrobidParser(segment_sentences=True)
|
|
|
|
)
|
|
|
|
docs = loader.load()
|
|
|
|
```
|
|
|
|
Chunk metadata will include bboxes although these are a bit funky to parse, see https://grobid.readthedocs.io/en/latest/Coordinates-in-PDF/
|