Comprehensive Python toolkit for RPA automation: email, logging, database tracking, browser automation, OCR, desktop automation, and more. Essential utilities for building robust automation workflows with Selenium, Botcity, and custom solutions.
Project description
RPA Suite
A comprehensive Python toolkit for Robotic Process Automation (RPA) development
Documentation • Installation • Quick Start • Features • Contributing
Overview
RPA Suite is a powerful and versatile Python library designed to streamline and optimize the development of Robotic Process Automation (RPA) projects. Built with simplicity and efficiency in mind, it provides a comprehensive set of tools that make automation development faster, more reliable, and more maintainable.
Whether you're working with Selenium, Botcity, or building custom automation solutions, RPA Suite offers the essential utilities you need to accelerate your development process.
Key Features
- 🕐 Time Management - Schedule executions, wait for specific times, and manage time-based automation flows
- 📧 Email Automation - Send emails via SMTP with HTML support and attachments
- 📝 Logging System - Comprehensive logging with file and stream support using Loguru
- 📁 File Operations - Screenshot capture, file counting, and flag file management
- 🗂️ Directory Management - Create and manage temporary directories with ease
- 🔍 Text Processing - Pattern matching, regex operations, and text validation
- 🌐 Browser Automation - Selenium-based browser control with Chrome support (optional)
- ⚡ Parallel & Async Execution - Run processes in parallel or asynchronously
- 🤖 Desktop Automation - PyAutoGUI-based desktop automation (Artemis module)
- 📄 OCR with AI - Document conversion with OCR capabilities (Iris module - optional)
- 💾 Database Tracking - Complete execution tracking and management system with multi-database support (SQLite, PostgreSQL, MySQL)
- 🎨 Colored Console Output - Beautiful terminal output with color-coded messages
- ✅ Data Validation - Email validation and pattern checking utilities
Installation
Basic Installation
Install RPA Suite using pip:
pip install rpa-suite
Or using conda:
conda install -c conda-forge rpa-suite
Optional Dependencies
For advanced features, install additional dependencies:
# Browser automation (Selenium)
pip install selenium webdriver-manager
# OCR with AI (Iris module)
pip install docling
# Desktop automation (Artemis - included by default)
# pyautogui is already included
Quick Start
After installation, import and use RPA Suite immediately:
from rpa_suite import rpa
# Send an email
rpa.email.send_smtp(
email_user="your@email.com",
email_password="your_password",
email_to="recipient@email.com",
subject_title="Hello from RPA Suite",
body_message="<p>This is a test email</p>"
)
# Schedule a function to run at a specific time
rpa.clock.exec_at_hour('14:30', my_function, arg1, arg2)
# Wait before executing a function
rpa.clock.wait_for_exec(30, my_function)
# Take a screenshot
rpa.file.screen_shot(filename="screenshot.png")
# Print colored messages
rpa.success_print("Operation completed successfully!")
rpa.error_print("An error occurred!")
Database Module Example
Track your automation executions with the Database module:
from rpa_suite import rpa
# Initialize database (SQLite by default)
db = rpa.database()
# Start tracking an execution
exec_id = db.start_execution(automation_name="My Automation Bot")
# Add items to process
item_id = db.add_item(execution_id=exec_id, item_identifier="item_001")
# Finish the execution
db.finish_execution(exec_id, status="completed")
Requirements
Core Dependencies
- Python 3.11+
- colorama
- colorlog
- email-validator
- loguru
- pillow
- pyautogui
- requests
- opencv-python
Optional Dependencies
- selenium (for browser automation)
- webdriver-manager (for browser automation)
- docling (for OCR/AI features)
- psycopg2-binary (for PostgreSQL support)
- mysql-connector-python (for MySQL support)
Features in Detail
Time Management (Clock Module)
Control execution timing and scheduling:
exec_at_hour()- Execute functions at specific timeswait_for_exec()- Wait before executing functionsexec_and_wait()- Execute and wait pattern
Email (Email Module)
Send emails with full SMTP support:
- HTML email support
- File attachments
- Custom SMTP configuration
- Email validation
Logging (Log Module)
Comprehensive logging system based on Loguru:
- File and console logging
- Multiple log levels (debug, info, warning, error, critical)
- Configurable log formats
- Automatic log rotation
File Operations (File Module)
File and screenshot management:
- Screenshot capture with custom naming
- Flag file creation/deletion for process tracking
- File counting with extension filtering
Database Tracking (Database Module)
Complete execution lifecycle management:
- Multi-database support (SQLite, PostgreSQL, MySQL)
- Execution tracking with status management
- Item queue processing
- Automatic interruption detection
- Reprocessing capabilities
- Comprehensive statistics and reporting
- Structured logging integration
Module Structure
Core Modules
- clock - Time management and scheduling
- date - Date and time formatting utilities
- email - SMTP email sending
- file - File operations and screenshots
- directory - Directory management
- log - Logging system
- printer - Colored console output
- regex - Pattern matching and regex operations
- validate - Data validation utilities
Advanced Modules
- database - Execution tracking and database management
- browser - Selenium-based browser automation (optional)
- parallel - Parallel process execution
- async - Asynchronous execution
- artemis - Desktop automation with PyAutoGUI
- iris - OCR and document conversion (optional)
Database Module Methods
Execution Management:
start_execution()- Start tracking a new executionfinish_execution()- Complete an executionget_execution()- Retrieve execution detailsget_executions()- List executions with filteringdetect_and_mark_interrupted_executions()- Auto-detect interruptions
Item Processing:
add_item()- Add item to processing queueadd_items()- Batch add itemsget_next_item_from_queue()- Get next item to processstart_processing_item()- Mark item as processingupdate_checkpoint()- Update processing checkpointfinish_item()- Complete item processingget_item()- Get item detailsget_items()- List items with filtering
Reprocessing:
can_reprocess_execution()- Check if execution can be reprocessedreprocess_interrupted_execution()- Restart interrupted executioncan_reprocess_item()- Check if item can be reprocessedreprocess_interrupted_item()- Restart interrupted item
Maintenance:
clear_pending_items()- Remove pending itemsclear_interrupted_items()- Remove interrupted itemsclear_successful_executions()- Remove successful executionsclear_failed_executions()- Remove failed executionsclear_executions_table()- Clear all executionsclear_items_table()- Clear all itemsclear_logs_table()- Clear all logsclear_database()- Clear entire database
Statistics & Logging:
add_log()- Add log entryget_logs()- Retrieve execution logsclear_logs()- Clear execution logsget_statistics()- Get comprehensive statistics
Documentation
For detailed documentation, usage examples, and API reference, visit:
- GitHub Wiki - Complete documentation and guides
- PyPI Project Page - Package information and releases
Contributing
Contributions are welcome! If you'd like to contribute to RPA Suite:
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Author
Camilo Costa de Carvalho
- GitHub: @CamiloCCarvalho
- LinkedIn: camilocostac
- Email: camilo.costa1993@gmail.com
Release Notes
Version 1.6.6
New Features:
- ✨ Added Database module for complete execution tracking and lifecycle management
- ✨ Multi-database support (SQLite, PostgreSQL, MySQL)
- ✨ Automatic interruption detection and recovery
- ✨ Item queue processing system
- ✨ Comprehensive statistics and reporting
Improvements:
- 🔧 Enhanced Suite instance initialization with proper type hints
- 🔧 Improved autocomplete and IDE support
- 🔧 Better docstrings and module descriptions
- 🔧 Refactored module structure for better maintainability
Version 1.6.5
- Initial release with core functionality
Made with ❤️ for the RPA community
Project details
Release history Release notifications | RSS feed
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 rpa_suite-1.6.6.tar.gz.
File metadata
- Download URL: rpa_suite-1.6.6.tar.gz
- Upload date:
- Size: 62.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
672fb60a8048a3b8da27cfd9d4c0be9f10cbb3e16e90becc79c0df42562eddcd
|
|
| MD5 |
3240e85bb9b1b862296618cf191f7cf2
|
|
| BLAKE2b-256 |
bda5266d06ca5e374e3c7d274b0c317ae4b180fb224786e1a8154090fcc871c0
|
File details
Details for the file rpa_suite-1.6.6-py3-none-any.whl.
File metadata
- Download URL: rpa_suite-1.6.6-py3-none-any.whl
- Upload date:
- Size: 67.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f91e63c603e7285b9b08e7b5087c0db1b4362e7589699e6b229fbd3ed60be91a
|
|
| MD5 |
2f9e9f8509c036839bc0eac697d4083c
|
|
| BLAKE2b-256 |
1fb262a6d373f62dc874f2fe07240d9373e1f8e9b033f7fa3ae8678a8a8d089a
|