Email MAPI Automation is a fully automated solution designed to process HTML tables embedded in the body of emails, modify the data, and update a database. Additionally, it generates and sends a new email with the updated data and includes a dynamically generated Excel file as an attachment.
-
Email Reception:
- The program captures emails from a specified address every 30 minutes, between 7:30 a.m. and 5:00 p.m.
- Emails include an HTML table embedded in the body.
-
Data Extraction and Modification:
- Data from the HTML table is extracted and converted into a manipulable format (Pandas DataFrame).
- Modifications are applied to the data, and new columns are created to ensure compatibility with the database entry.
-
Automated Email Generation:
- A new automated email is created, which includes:
- Information about the data transmitted and updated in the database.
- An
.xlsx
file containing the processed data attached to the email. - Recipients are automatically selected based on the processed data.
- A new automated email is created, which includes:
-
Database Update:
- After sending the email via Outlook, the processed tables are selected, and the database is updated accordingly.
The project uses the following Python libraries:
- pandas: For data manipulation and analysis.
- numpy: For advanced numerical operations.
- shutil: For file and directory management.
- os: For operating system interactions.
- BeautifulSoup: For HTML parsing and data extraction.
- re (Regex): For pattern matching and text manipulation.
- xlsxwriter: For creating Excel files.
- timestamp: For handling date and time.
- win32com.client: For Outlook automation to manage emails.
- Fully Automated: Automatic email and data processing.
- Email Management: Automated generation and sending of emails with updated data and attachments.
- Database Integration: Prepares data for seamless integration into an existing database.
- Dynamic Processing: Handles HTML tables of various formats dynamically.
- Operating System: Windows (required for Outlook automation).
- Python 3.x
- Additional dependencies installed via
pip
.
- Clone this repository:
git clone https://github.com/jparedesDS/email-mapi-automation.git
- Install the required dependencies:
pip install -r requirements.txt
- Configure the email address and time intervals in the configuration file.
- Run the main script:
python main.py
Contributions are welcome! If you'd like to improve this project, please:
- Fork the repository.
- Create a new branch (git checkout -b feature/new-feature).
- Make your changes and commit them (git commit -am 'Add new feature').
- Push your branch (git push origin feature/new-feature).
- Open a Pull Request.
This project is licensed under the MIT License. See the LICENSE file for details.