John Snow Labs: State-of-the-art NLP in Python
The John Snow Labs library provides a simple & unified Python API for delivering enterprise-grade natural language processing solutions:
- 15,000+ free NLP models in 250+ languages in one line of code. Production-grade, Scalable, trainable, and 100% open-source.
- Open-source libraries for Responsible AI (NLP Test), Explainable AI (NLP Display), and No-Code AI (NLP Lab).
- 1,000+ healthcare NLP models and 1,000+ legal & finance NLP models with a John Snow Labs license subscription.
Homepage: https://www.johnsnowlabs.com/
Docs & Demos: https://nlp.johnsnowlabs.com/
Features
Powered by John Snow Labs Enterprise-Grade Ecosystem:
- 🚀 Spark-NLP : State of the art NLP at scale!
- 🤖 NLU : 1 line of code to conquer NLP!
- 🕶 Visual NLP : Empower your NLP with a set of eyes!
- 💊 Healthcare NLP : Heal the world with NLP!
- ⚖ Legal NLP : Bring justice with NLP!
- 💲 Finance NLP : Understand Financial Markets with NLP!
- 🎨 NLP-Display Visualize and Explain NLP!
- 📊 NLP-Test : Deliver Reliable, Safe and Effective Models!
- 🔬 NLP-Lab : No-Code Tool to Annotate & Train new Models!
Installation
! pip install johnsnowlabs
from johnsnowlabs import nlp
nlp.load('emotion').predict('Wow that was easy!')
See the documentation for more details.
Usage
These are examples of getting things done with one line of code.
See the General Concepts Documentation for building custom pipelines.
nlp.load('ner').predict("Dr. John Snow is an British physician born in 1813")
Returns :
entities | entities_class | entities_confidence |
---|
John Snow | PERSON | 0.9746 |
British | NORP | 0.9928 |
1813 | DATE | 0.5841 |
nlp.load('answer_question').predict("What is the capital of Paris")
Returns :
text | answer |
---|
What is the capital of France | Paris |
nlp.load('sentiment').predict("Well this was easy!")
Returns :
text | sentiment_class | sentiment_confidence |
---|
Well this was easy! | pos | 0.999901 |
nlp.load('ner').viz('Bill goes to New York')
Returns:
For a full overview see the 1-liners Reference and the Workshop.
Use Licensed Products
To use John Snow Labs' paid products like Healthcare NLP, [Visual NLP], [Legal NLP], or [Finance NLP], get a license key and then call nlp.install() to use it:
! pip install johnsnowlabs
from johnsnowlabs import nlp
nlp.install()
nlp.start()
nlp.load('en.med_ner.oncology_wip').predict("Woman is on chemotherapy, carboplatin 300 mg/m2.")
Usage
These are examples of getting things done with one line of code.
See the General Concepts Documentation for building custom pipelines.
nlp.load('en.resolve.icd10cm.augmented')
.viz('Patient with history of prior tobacco use, nausea, nose bleeding and chronic renal insufficiency.')
returns:
nlp.load('relation.temporal_events')\
.viz('The patient developed cancer after a mercury poisoning in 1999 ')
returns:
Helpful Resources
Take a look at the official Johnsnowlabs page page: https://nlp.johnsnowlabs.com for user documentation and examples
Resource | Description |
---|
General Concepts | General concepts in the Johnsnowlabs library |
Overview of 1-liners | Most common used models and their results |
Overview of 1-liners for healthcare | Most common used healthcare models and their results |
Overview of all 1-liner Notebooks | 100+ tutorials on how to use the 1 liners on text datasets for various problems and from various sources like Twitter, Chinese News, Crypto News Headlines, Airline Traffic communication, Product review classifier training, |
Connect with us on Slack | Problems, questions or suggestions? We have a very active and helpful community of over 2000+ AI enthusiasts putting Johnsnowlabs products to good use |
Discussion Forum | More indepth discussion with the community? Post a thread in our discussion Forum |
Github Issues | Report a bug |
Custom Installation | Custom installations, Air-Gap mode and other alternatives |
The nlp.load(<Model>) function | Load any model or pipeline in one line of code |
The nlp.load(<Model>).predict(data) function | Predict on Strings , List of Strings , Numpy Arrays , Pandas , Modin and Spark Dataframes |
The nlp.load(<train.Model>).fit(data) function | Train a text classifier for 2-Class , N-Classes Multi-N-Classes , Named-Entitiy-Recognition or Parts of Speech Tagging |
The nlp.load(<Model>).viz(data) function | Visualize the results of Word Embedding Similarity Matrix , Named Entity Recognizers , Dependency Trees & Parts of Speech , Entity Resolution ,Entity Linking or Entity Status Assertion |
The nlp.load(<Model>).viz_streamlit(data) function | Display an interactive GUI which lets you explore and test every model and feature in Johnsowlabs 1-liner repertoire in 1 click. |
License
This library is licensed under the Apache 2.0 license.
John Snow Labs' paid products are subject to this End User License Agreement.
By calling nlp.install() to add them to your environment, you agree to its terms and conditions.