-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1 from adamduval/feat-readme
Feat: Add readma
- Loading branch information
Showing
10 changed files
with
85 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,84 @@ | ||
# snowflake_report_generator | ||
Automated report generation using only Snowflake. | ||
# 📊 Snowflake Automated PDF Report Generator 📊 | ||
|
||
The **Snowflake Automated PDF Report Generator** is a **proof-of-concept project** designed to showcase the **functionality** and **power** of **Snowflake Notebooks**. This project demonstrates how to create a fully **automated reporting pipeline** for a fictional company, **WidgetCo**, using only **Snowflake Notebook features**. | ||
|
||
The result? A **dynamic, daily PDF report** of **sales performance** for three product lines (**A, B, and C**), personalized for three different managers. These reports are sent automatically via **email** with **failure altering** and **archived for future reference**. | ||
|
||
|
||
https://github.com/user-attachments/assets/82e1c99c-a5b8-4a6c-967f-9b8965a58f10 | ||
|
||
## 🔧 Key Features | ||
|
||
- **Dynamic PDF Report Generation:** | ||
- Generate PDF reports for product lines A, B, and C. | ||
- Custom data tailored for each manager. | ||
|
||
<p align="center"> | ||
<img src="https://github.com/user-attachments/assets/d4057c0c-a6c4-4d00-be3a-9c079fcf37f9" alt="a-report" width="250"/> | ||
<img src="https://github.com/user-attachments/assets/a7840e76-a568-4b48-864d-8c8e0e0de551" alt="b-report" width="250"/> | ||
<img src="https://github.com/user-attachments/assets/7d0ddca8-c6da-41bb-8e83-3558f9815dd8" alt="c-report" width="250"/> | ||
</p> | ||
|
||
- **Email Failure Alerts:** | ||
- Automatic email notifications in case of report generation or delivery failures. | ||
|
||
data:image/s3,"s3://crabby-images/aba5a/aba5af7d70988cf4df7204eb48bf3160957a7c19" alt="email-warning" | ||
|
||
- **Customizable Dynamic Emails:** | ||
- Each manager receives a personalized email with their respective report. | ||
|
||
data:image/s3,"s3://crabby-images/515fc/515fc3e9e3a3950c74b1aa336dd991992a7518e0" alt="email-inbox" | ||
|
||
- **Visualize Reports During Development:** | ||
- View the report directly within the notebook environment without needing to save it to a stage. | ||
|
||
data:image/s3,"s3://crabby-images/c299d/c299db909c9348eeaebbf0a155195d22542ba81e" alt="dark-report-in-nb" | ||
|
||
- **Archive Management:** | ||
- All PDF reports are securely archived to an internal stage for easy future reference. | ||
|
||
data:image/s3,"s3://crabby-images/87e81/87e8112afae2fdf597076a12cb3763acb81e5c5e" alt="stage-main" | ||
data:image/s3,"s3://crabby-images/5bc6a/5bc6a7e85288785404afa8e8437580d3c1c1f8d5" alt="stage-a" | ||
|
||
- **Simplified Workflow Management:** | ||
- A single orchestration notebook handles the entire process, supporting both ad-hoc runs and scheduled automation. | ||
|
||
--- | ||
|
||
## 🏗️ Requirements | ||
|
||
- A Snowflake account with access to Snowflake Notebooks. | ||
|
||
--- | ||
|
||
## ⚖️ Step-by-Step Walkthrough | ||
|
||
### 1. Setup | ||
1. Copy all the notebooks provided into your Snowflake environment. | ||
|
||
### 2. Data Engineering | ||
- Run the `_00_REPORT_GEN__ENG` notebook to prepare the data for the project. | ||
- This notebook generates a sales fact table with randomized sales data for three fictional widgets. | ||
- It also creates a stage to store the generated PDF reports. | ||
|
||
### 3. Report Development | ||
- Run the `01_REPORT_GEN__REPORT` notebook to view and test the demo report. | ||
- Add the logo file to the notebook from `\resources]\logo.pgn` or create your own logo | ||
- Customize the report as needed. | ||
- Preview the report as a JPG directly within the notebook. | ||
|
||
### 4. Email Integration Setup | ||
- Run the `_02_REPORT_GEN__EMAIL_CONFIG` notebook to configure email integration. | ||
- Update the notebook with your email addresses. | ||
|
||
### 5. Email Development | ||
- Run the `_03_REPORT_GEN__SEND_EMAIL` notebook to preview email content. | ||
- Note: Email formatting preview may have limitations due to Streamlit. | ||
|
||
### 6. Automate Report Generation and Delivery | ||
- Run the `_04_REPORT_GEN__PIPELINE` notebook to generate and send the reports. | ||
- Schedule this notebook for daily execution to automate the reporting process. | ||
|
||
--- | ||
|
||
## 🚀 Reach out if you have any questions or want to chat about the project. I'd love to hear your thoughts! |
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
|