Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samedwardes/spacytextblob
A TextBlob sentiment analysis pipeline component for spaCy.
https://github.com/samedwardes/spacytextblob
natural-language-processing nlp python spacy
Last synced: about 22 hours ago
JSON representation
A TextBlob sentiment analysis pipeline component for spaCy.
- Host: GitHub
- URL: https://github.com/samedwardes/spacytextblob
- Owner: SamEdwardes
- License: mit
- Created: 2020-11-11T07:00:33.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-12T20:19:27.000Z (3 months ago)
- Last Synced: 2025-01-11T11:09:45.950Z (about 22 hours ago)
- Topics: natural-language-processing, nlp, python, spacy
- Language: Jupyter Notebook
- Homepage: https://spacytextblob.netlify.app/
- Size: 840 KB
- Stars: 56
- Watchers: 3
- Forks: 8
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# spacytextblob
[![PyPI version](https://badge.fury.io/py/spacytextblob.svg)](https://badge.fury.io/py/spacytextblob)
[![pytest](https://github.com/SamEdwardes/spacytextblob/actions/workflows/pytest.yml/badge.svg)](https://github.com/SamEdwardes/spacytextblob/actions/workflows/pytest.yml)
![PyPI - Downloads](https://img.shields.io/pypi/dm/spacytextblob?label=PyPi%20Downloads)
[![Netlify Status](https://api.netlify.com/api/v1/badges/e2f2caac-7239-45a2-b145-a00205c3befb/deploy-status)](https://app.netlify.com/sites/spacytextblob/deploys)A TextBlob sentiment analysis pipeline component for spaCy.
- [Docs](https://spacytextblob.netlify.app/)
- [GitHub](https://github.com/SamEdwardes/spacytextblob)
- [PyPi](https://pypi.org/project/spacytextblob/)
- [spaCy Universe](https://spacy.io/universe/project/spacy-textblob)## Install
Install *spacytextblob* from PyPi.
```bash
pip install spacytextblob
```TextBlob requires additional data to be downloaded before getting started.
```bash
python -m textblob.download_corpora
```spaCy also requires that you download a model to get started.
```bash
python -m spacy download en_core_web_sm
```## Quick Start
*spacytextblob* allows you to access all of the attributes created of the `textblob.TextBlob` class but within the spaCy framework. The code below will demonstrate how to use *spacytextblob* on a simple string.
```python
import spacy
from spacytextblob.spacytextblob import SpacyTextBlobnlp = spacy.load('en_core_web_sm')
text = "I had a really horrible day. It was the worst day ever! But every now and then I have a really good day that makes me happy."
nlp.add_pipe("spacytextblob")
doc = nlp(text)print(doc._.blob.polarity)
# -0.125print(doc._.blob.subjectivity)
# 0.9print(doc._.blob.sentiment_assessments.assessments)
# [(['really', 'horrible'], -1.0, 1.0, None), (['worst', '!'], -1.0, 1.0, None), (['really', 'good'], 0.7, 0.6000000000000001, None), (['happy'], 0.8, 1.0, None)]
```In comparison, here is how the same code would look using `TextBlob`:
```python
from textblob import TextBlobtext = "I had a really horrible day. It was the worst day ever! But every now and then I have a really good day that makes me happy."
blob = TextBlob(text)print(blob.sentiment_assessments.polarity)
# -0.125print(blob.sentiment_assessments.subjectivity)
# 0.9print(blob.sentiment_assessments.assessments)
# [(['really', 'horrible'], -1.0, 1.0, None), (['worst', '!'], -1.0, 1.0, None), (['really', 'good'], 0.7, 0.6000000000000001, None), (['happy'], 0.8, 1.0, None)]
```## Quick Reference
*spacytextblob* performs sentiment analysis using the [TextBlob](https://textblob.readthedocs.io/en/dev/quickstart.html) library. Adding *spacytextblob* to a spaCy nlp pipeline creates a new extension attribute for the `Doc`, `Span`, and `Token` classes from spaCy.
- `Doc._.blob`
- `Span._.blob`
- `Token._.blob`The `._.blob` attribute contains all of the methods and attributes that belong to the `textblob.TextBlob` class Some of the common methods and attributes include:
- **`._.blob.polarity`**: a float within the range [-1.0, 1.0].
- **`._.blob.subjectivity`**: a float within the range [0.0, 1.0] where 0.0 is very objective and 1.0 is very subjective.
- **`._.blob.sentiment_assessments.assessments`**: a list of polarity and subjectivity scores for the assessed tokens.See the [textblob docs](https://textblob.readthedocs.io/en/dev/api_reference.html#textblob.blob.TextBlob) for the complete listing of all attributes and methods that are available in `._.blob`.
## Reference and Attribution
- TextBlob
- [https://github.com/sloria/TextBlob](https://github.com/sloria/TextBlob)
- [https://textblob.readthedocs.io/en/latest/](https://textblob.readthedocs.io/en/latest/)
- negspaCy (for inspiration in writing pipeline and organizing repo)
- [https://github.com/jenojp/negspacy](https://github.com/jenojp/negspacy)
- spaCy custom components
- [https://spacy.io/usage/processing-pipelines#custom-components](https://spacy.io/usage/processing-pipelines#custom-components)