Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/rubydamodar/protext-analyzer

ProText Analyzer is a powerful tool for extracting insights from text. It conducts sentiment analysis, categorizing content as positive, negative, or neutral, while also assessing readability and linguistic complexity. Ideal for businesses and researchers, it enhances understanding of textual data.
https://github.com/rubydamodar/protext-analyzer

complex-word-definition data-cleaning-techniques data-extraction linguistic-complexity metrics-explained readability-analysis sentiment-analysis syllable-counting-methodology tokenization-process

Last synced: about 2 months ago
JSON representation

ProText Analyzer is a powerful tool for extracting insights from text. It conducts sentiment analysis, categorizing content as positive, negative, or neutral, while also assessing readability and linguistic complexity. Ideal for businesses and researchers, it enhances understanding of textual data.

Awesome Lists containing this project

README

        

![Blackcoffer Logo](https://blackcoffer.com/wp-content/uploads/2023/10/Black-720x172-4.png)

![ProText Analyzer](https://see.fontimg.com/api/rf5/YzROj/NWU1YzRiZjQxYmU1NDJlM2E4YWU0OGE5OTI4YjU2MzIudHRm/UHJvVGV4dCBBbmFseXplcg/sdglitchdemo-regular.png?r=fs&h=50&w=1250&fg=590458&bg=FFFFFF&tb=1&s=40)

# ProText Analyzer

> ## Note
> Apologies, but I did not use the NLTK package for some tasks. Instead, I used:
> - **TextBlob** for sentiment analysis
> - **spaCy** for various text processing tasks
> - **Syllapy** for counting syllables in words

## Project Structure

๐Ÿ—‚ Directories and Files

๐Ÿ“ Cleaned Articles
- **cleaned_articles:** Contains cleaned articles ready for analysis.

๐Ÿ“‚ Extracted Articles
- **extracted_articles:** Holds raw articles extracted for the project.

๐Ÿ“š Master Dictionary
- **master_dictionary:** Collection of files for sentiment analysis.
- `cleaned_negative_words.txt`: List of cleaned negative words.
- `cleaned_positive_words.txt`: List of cleaned positive words.
- `negative-words.txt`: Raw negative words for sentiment analysis.
- `positive-words.txt`: Raw positive words for sentiment analysis.

๐Ÿ“‘ Project Introduction
- **project_introduction:** Overview and objectives of the project.

๐Ÿงช Test Assessment
- **test_assessment:** Contains test assignments and notebooks.
- `dataextraction.ipynb`: Jupyter Notebook for data extraction tasks.
- `testassessment.ipynb`: Jupyter Notebook for additional test assessments.

๐Ÿ’ป Code and Markdown
- **testassignment:** Code and markdown files related to assignments.
- `Code + Markdown/`: Contains code snippets and explanations.
- `Run All/`: Script to execute all code cells in notebooks.

๐Ÿšซ Stop Words
- **Stop Words:** Directory with various stop words files for preprocessing.

๐Ÿ“Š Text Analysis
- **text_analysis:** Files for performing text analysis.
- `textanalysis.ipynb`: Jupyter Notebook for text analysis.
- `sentiment_analysis.log`: Log file for sentiment analysis results.
- `textblob_sentiment_result.csv`: CSV file with sentiment analysis results.

๐Ÿ“ˆ Additional Files
- **additional_files:** Summary results and metrics.
- `analysis_results.csv`: Various analysis results.
- `final_text_analysis_results.xlsx`: Final compiled analysis results.

## Blackcoffer Test Assignment

### Company Information
- **Consulting Website:** Blackcoffer | LSA Lead
- **Web App Products:** Netclan | Insights | Hire Kingdom | Workcroft
- **Mobile App Products:** Netclan | Bwstory

### Assignment Overview
1. **Objective:** Extract textual data from provided URLs and perform text analysis.
2. **Data Extraction:**
- Input from `Input.xlsx`
- Tools: Python, BeautifulSoup, Selenium, Scrapy.
3. **Data Analysis:**
- Output in CSV or Excel format.
- Variables include Positive Score, Negative Score, Polarity Score, etc.
4. **Timeline:** Duration of 6 days.
5. **Submission:** Via Google Form with required files.

### Methodology
- **Sentimental Analysis:** Clean text using stop words, create dictionaries of positive/negative words, and extract variables.
- **Readability Analysis:** Calculate average sentence length, percentage of complex words, and Fog Index.

**Objective**:
The **ProText-Analyzer** project extracts article content from provided URLs and performs various text analysis tasks like sentiment scoring, readability measurement, and more. The results are structured in a clean and organized format, ready for review and further use.

## Project Overview

The goal of **ProText-Analyzer** is to:
1. **Extract Textual Data**: Fetch the article content from URLs provided in the `Input.xlsx` file.
2. **Perform Textual Analysis**: Calculate the following metrics:
- Sentiment scores (positive, negative, polarity, subjectivity)
- Readability scores (Fog Index, Avg. Sentence Length)
- Word count, syllable count, and other word statistics

---

## Technologies Used

- **Python** ๐Ÿ
- Libraries:
- `TextBlob` for sentiment analysis
- `spaCy` for text processing tasks (tokenization, POS tagging, etc.)
- `Syllapy` for syllable counting
- `BeautifulSoup` for HTML parsing during data extraction
- `Requests` for handling HTTP requests
- **Pandas** for data management
- **Excel/CSV** for input/output handling

---

## Installation

1. Clone the repository to your local machine:
```bash
git clone https://github.com/rubydamodar/ProText-Analyzer.git
cd ProText-Analyzer
```

2. Install the required Python libraries:
```bash
pip install -r requirements.txt
```

---

## Data Extraction Process

The **ProText-Analyzer** extracts the article title and body from each URL listed in the `Input.xlsx` file and stores the text for further analysis.

### Process Overview:
1. **Read Input File**: Load the URLs and their associated IDs from `Input.xlsx`.
2. **Extract Article Content**:
- Fetch HTML content using `requests`.
- Parse the HTML using `BeautifulSoup` to extract the article's title and body.
- Save the extracted content into text files named after the `URL_ID`.

### File Management:
- Each article's content is saved in text files, facilitating a clean process for further analysis.
- Error handling ensures proper management of file I/O and network issues.

---

## Text Analysis Process

The extracted text undergoes several analysis steps to compute the following variables:

1. **Sentiment Analysis**:
- Implemented using `TextBlob` to compute **Positive Score**, **Negative Score**, **Polarity Score**, and **Subjectivity Score**.
- Text is cleaned by removing stop words and irrelevant characters.

2. **Readability Analysis**:
- Calculated using the Gunning Fog Index.
- Additional metrics: **Average Sentence Length**, **Percentage of Complex Words**, and **Fog Index**.

3. **Word-Level Metrics**:
- **Word Count**, **Complex Word Count**, **Syllable Count per Word** (via `syllapy`), **Personal Pronouns Count** (using regex), and **Average Word Length**.

---

## Output Structure

The results are saved in **Excel/CSV** format as per the structure outlined in `Output Data Structure.xlsx`. The following variables are included:
- Positive Score
- Negative Score
- Polarity Score
- Subjectivity Score
- Average Sentence Length
- Complex Word Count
- Word Count
- Syllable Count
- Personal Pronouns Count
- Average Word Length

---

## How to Run

1. **Data Extraction**:
Run the script to extract article data from the URLs:
```bash
python data_extraction.py
```

2. **Text Analysis**:
Run the text analysis script to process the extracted articles:
```bash
python text_analysis.py
```

The results will be saved in the output directory in `.csv` or `.xlsx` format.

---

## Challenges and Solutions

- **Error Handling**: Implemented robust error handling to manage potential network and file-related issues.
- **Text Processing**: Utilized advanced tools like `spaCy` for precise text tokenization and POS tagging, and `syllapy` for syllable counting.
- **Personal Pronouns**: Regex was used to accurately capture pronouns without including words like "US" mistakenly.

---

## Contributing

We welcome contributions to enhance **ProText-Analyzer**! To contribute:
1. Fork the repository.
2. Create a new branch for your changes.
3. Submit a pull request with a detailed description of your changes.

---

## License

This project is licensed under the [MIT License](LICENSE).

---

### Project Maintainer
Ruby Poddar
Email: [email protected]