Stanford openie python
Stanford Open Information Extraction made simple!
*Supports the latest CoreNLP library 4.5.3 (as of 2023-03-10).* The project is written primarily in Python, distributed under the ISC License license, first published in 2016. Key topics include: extraction, nlp, python-wrapper, stanford, stanford-openie.
Python wrapper for Stanford OpenIE (MacOS/Linux)
Supports the latest CoreNLP library 4.5.3 (as of 2023-03-10).
Open information extraction (open IE) refers to the extraction of structured relation triples from plain text, such that
the schema for these relations does not need to be specified in advance. For example, Barack Obama was born in Hawaii
would create a triple (Barack Obama; was born in; Hawaii), corresponding to the open domain relation "was born in".
CoreNLP is a Java implementation of an open IE system as described in the paper:
More information can be found here. The OpenIE library is only available
in english.
Installation
You need python3 and Java (JRE) installed. Java is used by the CoreNLP library.
Make sure Java is installed first.
bashjava -version
Then install the lib.
bashpip install stanford_openie
Example
pythonfrom openie import StanfordOpenIE # https://stanfordnlp.github.io/CoreNLP/openie.html#api # Default value of openie.affinity_probability_cap was 1/3. properties = { 'openie.affinity_probability_cap': 2 / 3, } with StanfordOpenIE(properties=properties) as client: text = 'Barack Obama was born in Hawaii. Richard Manning wrote this sentence.' print('Text: %s.' % text) for triple in client.annotate(text): print('|-', triple) graph_image = 'graph.png' client.generate_graphviz_graph(text, graph_image) print('Graph generated: %s.' % graph_image) with open('corpus/pg6130.txt', encoding='utf8') as r: corpus = r.read().replace('\n', ' ').replace('\r', '') triples_corpus = client.annotate(corpus[0:5000]) print('Corpus: %s [...].' % corpus[0:80]) print('Found %s triples in the corpus.' % len(triples_corpus)) for triple in triples_corpus[:3]: print('|-', triple) print('[...]')
Expected output
|- {'subject': 'Barack Obama', 'relation': 'was', 'object': 'born'}
|- {'subject': 'Barack Obama', 'relation': 'was born in', 'object': 'Hawaii'}
|- {'subject': 'Richard Manning', 'relation': 'wrote', 'object': 'sentence'}
Graph generated: graph.png.
Corpus: According to this document, the city of Cumae in Ćolia, was, at an early period [...].
Found 1664 triples in the corpus.
|- {'subject': 'city', 'relation': 'is in', 'object': 'Ćolia'}
|- {'subject': 'Menapolus', 'relation': 'son of', 'object': 'Ithagenes'}
|- {'subject': 'Menapolus', 'relation': 'was Among', 'object': 'immigrants'}
It will generate a GraphViz DOT in graph.png:
Note: Make sure GraphViz is installed beforehand. Try to run the dot command to see if this is the case. If not,
run sudo apt-get install graphviz if you're running on Ubuntu. On MacOS, it is brew install graphviz.
References
- https://www.kaggle.com/asitang/stanford-resources
- https://www.kaggle.com/geofila/corenlp?select=stanford-corenlp-full-2018-10-05
Cite
@misc{StanfordOpenIEWrapper,
author = {Philippe Remy},
title = {Python wrapper for Stanford OpenIE},
year = {2020},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/philipperemy/Stanford-OpenIE-Python}},
}
Contributors
<a href="https://github.com/philipperemy/stanford-openie-python/graphs/contributors"> <img src="https://contrib.rocks/image?repo=philipperemy/stanford-openie-python" /> </a>Contributors
Showing top 5 contributors by commit count.
