A simple help for writers
Project description
My Ghost Writer
A simple helper for writers.
Overview
My Ghost Writer is a web application that analyzes text and provides words frequency statistics. It allows users to upload or type in a text, and then displays the most common words, their frequencies and their position with the text editor. The application uses natural language processing (NLP) techniques to stem words, making it easier to identify patterns and trends in the text.
Features
- Analyse large texts and provide words frequency statistics
- Use NLP to stem words for more accurate results
- Support for uploading or typing in text
- User-friendly interface with a simple editor and display of word frequencies
Technologies Used
- Python 3.10+ (FastAPI web framework)
- a Vanilla JavaScript frontend, playwright for E2E testing
nltklibrary for natural language processingstructlogfor logging and error handling
Getting Started
In a Linux/WSL environment (I didn't tried with MacOS or Windows):
-
Clone the repository using
git clone https://github.com/trincadev/my_ghost_writer,cd my_ghost_writer -
Create a virtualenv and install the project dependencies using an existing python version with
- poetry (
poetry env use 3.12.10,poetry install,eval $(poetry env activate)) python -m venv .venv,source .venv/bin/activate,pip install -r requirements.txt(and the other requirements files if you need also the webserver and/or the test environment)
- poetry (
-
Run the application using:
python my_ghost_writer/app.pyusing the python app.py file pathpython -m ghost_writer.app.pyusing the python module
Run as a python module
If using the webserver with the module (python -m ghost_writer.app.py) it's necessary one of these env variables:
STATIC_FOLDERto define a custom path for the static folder. Probably you should also download the static files:index.htmlindex.jsindex.css
API_MODEto avoid mounting the static folder. This will define only the API endpoints/health/words-frequency
Installation script
An alternate way to use the project is installing it using install.sh. e.g.
bash ./install.sh
If you want to run my custom frontend using this script (available on default on port 7860):
- use the install-only option
- define a custom path for
STATIC_FOLDERand use it for the module execution:
# run the script with the install-only option
bash install.sh -i
# run the python module with the custom STATIC_FOLDER env variable, e.g.
# if you already created STATIC_FOLDER within the current directory with the needed files within, see above
export STATIC_FOLDER=$PWD/static
python -m my_ghost_writer.app
Contributing
Pull requests are welcome! Please make sure to test your changes thoroughly before submitting a pull request.
This project is still in its early stages, and there are many features that can be added to make it more useful for writers.
If you have any suggestions or would like to contribute to the project, please don't hesitate to reach out!
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file my_ghost_writer-0.3.0.tar.gz.
File metadata
- Download URL: my_ghost_writer-0.3.0.tar.gz
- Upload date:
- Size: 19.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.2 CPython/3.12.3 Linux/5.15.167.4-microsoft-standard-WSL2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
86c883b24b7bef12e15aff4b3153a1d19e4c08ba30668726b14105b248877b21
|
|
| MD5 |
79e86fc3fda3910199b7018ceb7106ed
|
|
| BLAKE2b-256 |
e0a86e7840e1aa2a40e9488ee712b59a91ed7fbbbd37fe0a5a60fed26ec8d2d5
|
File details
Details for the file my_ghost_writer-0.3.0-py3-none-any.whl.
File metadata
- Download URL: my_ghost_writer-0.3.0-py3-none-any.whl
- Upload date:
- Size: 22.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.2 CPython/3.12.3 Linux/5.15.167.4-microsoft-standard-WSL2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3e7d6270d278de3cde8f2fffbda19636585d2f5b5eed105025a4d0b7951c7994
|
|
| MD5 |
4c7cd686bc60fdf6e7352580ea56f7e9
|
|
| BLAKE2b-256 |
08b2b1e3bba470b2dfdc599b612b47427e9de2af847463d557a8b44440efdb22
|