Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kialanpillay/senti-api
Senti is a blazingly fast API for sentiment analysis with NLTK.
https://github.com/kialanpillay/senti-api
Last synced: 2 months ago
JSON representation
Senti is a blazingly fast API for sentiment analysis with NLTK.
- Host: GitHub
- URL: https://github.com/kialanpillay/senti-api
- Owner: kialanpillay
- Created: 2020-07-20T17:25:30.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-01-11T21:20:58.000Z (about 1 year ago)
- Last Synced: 2024-06-08T23:35:01.387Z (7 months ago)
- Language: Python
- Homepage: https://senti-ment-api.herokuapp.com/
- Size: 213 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-blazingly-fast - senti-api - Senti is a blazingly fast API for sentiment analysis with NLTK. (Python)
README
# Senti API
## About
Senti API is a Python-based RESTful API server built using the popular Flask micro web framework. Senti API uses NLTK, a leading Natural Language Processing Python framework, to expose several sentiment analysis endpoints to clients.Senti API currently provides two distinct sentiment analysis methods using different algorithms: Naive Bayes classification and VADER (Valence Aware Dictionary and sEntiment Reasoner), as well as a bulk analysis endpoint for multiple documents using the VADER approach.
Senti API is hosted on [Heroku](https://senti-ment-api.herokuapp.com/) and is publicly accessible and key-free for the moment. Visit the API to browse the basic documentation generated using Swagger and flask-restx.
Test out the API using Senti Playground, a web application designed for just for that, and has a host of other features.
Senti API is also backed by a AWS DynamoDB database which is currently used to persist our Gen Z corpora, which will be used for further training of our classifiers.## Endpoints
```GET /bayes/{text}``` - This endpoint will return a sentiment classification for a requested string of text. Note that the Naive Bayes classifier does not produce polarity scores.```GET /vader/{text}``` - This endpoint will return a sentiment classification and polarity scores for a requested string of text.
```POST /bulk``` - This endpoint will return the sentiment classification and polarity scores for a array of requested documents (text).
```POST /corpus``` - This endpoint will receive a phrase submission from a client and insert it into a DynamoDB table.
```GET /corpus``` - This endpoint will return the record count of a DynamoDB table. Note that counts are only updated every six hours as per the DynamoDB documentation.
## Run
Install the following Python packages using ```pip```
|Dependencies|
|------------|
re
requests
boto3
uuid
flask
flask_restx
nltkYou will also need to install the NLTK data packages listed in ```nltk.txt```.
See this [documentation](https://www.nltk.org/data.html) for more information.To run the server locally (```localhost:5000```), run the following command in terminal:
```python3 wsgi.py```
This will start the server in development mode. Server logs will be printed to console.
## UCT DevSoc Competition Notes
Senti API is hosted on a free-plan Heroku dyno, and thus the server only spins-up on user request. The consequence of this is that an initial cold-start request is often much slower than subsequent API calls, so please do be patient.
Secrets management for the AWS DynamoDB backend integration is acheived using Heroku Environment Variables.Senti API primarily leverages Flask and NLTK to provide its functionality, and boto3 for AWS integration. NLTK data is downloaded into the production environment on Heroku. Although a pickled classifier is used for production to prevent constant training of the classifier on server startup, the source code for model training using the NLTK tweets dataset is also present in the repo for perusal. All the source code is documented comprehensively and confirms to PEP standards. Additional comments are also present when deemed essential.
I hope you find this API useful, and have fun using Senti Playground to try out this API, and explore other sentiment analysis features!