Personal finance tracker with Telegram Bot, Google Gemini Vision, and Sheets
Personal Finance AI Agent – Telegram Bot (n8n Workflow)
A fully automated Telegram-based personal finance tracker that:
- Accepts receipts as images, PDFs, or plain text
- Uses Google Gemini Vision for OCR & intelligent extraction
- Logs every expense into Google Sheets
- Stores receipt images/PDFs in Google Drive
- Answers natural-language spending questions ("How much did I spend on food last month?", "Compare this month vs last month", etc.)
Built entirely with n8n – 100% self-hostable, no-code/low-code.
How It Works (Overview)
-
You send a message to your Telegram bot
→ Photo of a receipt, PDF, or just text like "Nov 10 – 2500 NGN – Uber" -
Switch node detects the message type:
- Photo → Branch 0
- Document (PDF/other) → Branch 1
- Pure text → Branch 2 (goes straight to query agent)
-
Receipt Processing Path (Images & PDFs)
- Files downloaded from Telegram → uploaded to Google Drive ("Monthly receipts" folder)
- Images → OCR with Gemini Vision
PDFs → native PDF text extraction - Extracted text + Drive link → merged → sent to Gemini AI Agent
- AI extracts: Date (YYYY-MM-DD) • Amount (NGN) • Description • Category
(food, transportation, subscriptions, takeouts, entertainment, gift, electricity, repairs, other stuffs) - Clean JSON → appended to Google Sheets → friendly confirmation sent back
-
Spending Query Path (Text questions)
- Second AI Agent with access to the live Google Sheet + calculator + memory
- Answers anything: totals, breakdowns, comparisons, trends, percentages…
Live Google Sheet (Template)
You can make a copy of the exact sheet the bot uses:
https://docs.google.com/spreadsheets/d/1kwWJquPpwL9vt9U06a4f4phXq5jZjaGazvh2V69FGoc/edit?usp=sharing
Just click File → Make a copy and use your copy’s ID in the workflow.
Setup Steps (Step-by-Step)
Prerequisites
- n8n instance (cloud or self-hosted)
- Telegram bot (created via @BotFather)
- Google account
1. Create Telegram Bot
- Message @BotFather →
/newbot - Copy the bot token
- In n8n → Credentials → New Telegram API credential → paste token
2. Google Setup
- Make a copy of the sheet above
→ Copy the new spreadsheet ID from the URL - Create a Google Drive folder called "Monthly receipts" (or any name) → copy folder ID
- Enable Gemini API in Google Cloud (or use your existing key)
- In n8n create these credentials:
- Google Sheets OAuth2 API
- Google Drive OAuth2 API
- Google Gemini (PaLM) API
3. Import Workflow
- Copy the full JSON from the original file
- n8n → Workflows → Import → paste → Import
4. Update IDs & Credentials
After import, configure these nodes:
| Node | What to Change | |-----------------------------------|-----------------------------------------------------| | Telegram Trigger + all Telegram nodes | Your Telegram credential | | Google Sheets nodes | Your Google Sheets credential + new Sheet ID | | Google Drive "Upload file" nodes | Paste your "Monthly receipts" folder ID | | Gemini nodes | Your Gemini credential | | AI Agent & AI Agent1 | Verify model, memory, tools are connected |
5. Activate & Test
- Click Activate
- Start chatting with your bot on Telegram
Test commands
- Send a photo/PDF receipt
- Type:
How much did I spend last month? - Type:
Show me food spending this month vs last month
You’ll get instant replies and see new rows appear in your sheet!
Features
- Zero manual entry ever again
- Works with handwritten receipts
- Smart categorization
- Natural-language spending insights
- All data stays 100% in your Google account
- Completely private & self-hostable
- NGN-native (Naira)
Never track expenses manually again!
Personal Finance Tracker with Telegram Bot, Google Gemini Vision, and Sheets
This n8n workflow automates the process of tracking personal finances by leveraging a Telegram bot, Google Gemini Vision for image analysis, and Google Sheets for data storage. It allows users to quickly log expenses by sending images or text messages to a Telegram bot.
What it does
- Listens for Telegram Messages: The workflow is triggered when a user sends a message to a configured Telegram bot.
- Identifies Message Type: It checks if the incoming Telegram message contains an image or a text message.
- Processes Image-based Expenses:
- If an image is received (e.g., a receipt), it downloads the image from Google Drive (assuming Telegram stores media there).
- It then uses Google Gemini Vision (via an AI Agent) to extract relevant expense details from the image (e.g., amount, category, merchant).
- A "Structured Output Parser" helps in standardizing the extracted data.
- Processes Text-based Expenses:
- If a text message is received, it directly routes the text to the AI Agent for parsing.
- The AI Agent, powered by Google Gemini Chat Model, interprets the text to identify expense details.
- A "Structured Output Parser" ensures the data is in a consistent format.
- Handles Unrecognized Input: If the AI Agent cannot parse the input (either image or text) into a structured expense, it sends a message back to the user indicating the failure.
- Stores Data in Google Sheets: For successfully parsed expenses, the workflow appends the extracted details (date, amount, category, description) to a designated Google Sheet.
- Confirms Transaction: After successfully logging an expense, the bot sends a confirmation message back to the user via Telegram.
- Maintains Conversation Context: A "Simple Memory" node is included, suggesting the workflow maintains conversational context for a more natural interaction with the AI Agent.
- Includes a Calculator Tool: The AI Agent is equipped with a "Calculator" tool, implying it can handle calculations if needed during expense processing.
Prerequisites/Requirements
- n8n Instance: A running n8n instance.
- Telegram Bot: A Telegram bot token and the chat ID(s) of authorized users.
- Google Account:
- Google Drive: For storing and accessing images sent via Telegram.
- Google Sheets: A spreadsheet to log personal finance transactions.
- Google Gemini API Key: For accessing Google Gemini Vision and Chat Model capabilities.
- n8n Credentials: Configured credentials for Telegram, Google Sheets, Google Drive, and Google Gemini within your n8n instance.
Setup/Usage
- Import the Workflow: Download the provided JSON and import it into your n8n instance.
- Configure Credentials:
- Telegram Trigger & Telegram Node: Set up your Telegram Bot API Token and specify the
Chat IDof the user(s) who will interact with the bot. - Google Drive Node: Configure your Google Drive credentials (OAuth 2.0 recommended) and specify the folder where Telegram media files are saved.
- Google Sheets Node: Configure your Google Sheets credentials (OAuth 2.0 recommended) and specify the
Spreadsheet IDandSheet Namewhere expenses will be logged. - Google Gemini Chat Model & Google Gemini Nodes: Set up your Google Gemini API Key.
- Telegram Trigger & Telegram Node: Set up your Telegram Bot API Token and specify the
- Activate the Workflow: Once all credentials are configured, activate the workflow.
- Interact with the Bot:
- Send an image of a receipt to your Telegram bot.
- Send a text message describing an expense (e.g., "Bought groceries for $50 at SuperMart").
- The bot will process the input, log it to your Google Sheet, and send a confirmation message.
Related Templates
Generate song lyrics and music from text prompts using OpenAI and Fal.ai Minimax
Spark your creativity instantly in any chat—turn a simple prompt like "heartbreak ballad" into original, full-length lyrics and a professional AI-generated music track, all without leaving your conversation. 📋 What This Template Does This chat-triggered workflow harnesses AI to generate detailed, genre-matched song lyrics (at least 600 characters) from user messages, then queues them for music synthesis via Fal.ai's minimax-music model. It polls asynchronously until the track is ready, delivering lyrics and audio URL back in chat. Crafts original, structured lyrics with verses, choruses, and bridges using OpenAI Submits to Fal.ai for melody, instrumentation, and vocals aligned to the style Handles long-running generations with smart looping and status checks Returns complete song package (lyrics + audio link) for seamless sharing 🔧 Prerequisites n8n account (self-hosted or cloud with chat integration enabled) OpenAI account with API access for GPT models Fal.ai account for AI music generation 🔑 Required Credentials OpenAI API Setup Go to platform.openai.com → API keys (sidebar) Click "Create new secret key" → Name it (e.g., "n8n Songwriter") Copy the key and add to n8n as "OpenAI API" credential type Test by sending a simple chat completion request Fal.ai HTTP Header Auth Setup Sign up at fal.ai → Dashboard → API Keys Generate a new API key → Copy it In n8n, create "HTTP Header Auth" credential: Name="Fal.ai", Header Name="Authorization", Header Value="Key [Your API Key]" Test with a simple GET to their queue endpoint (e.g., /status) ⚙️ Configuration Steps Import the workflow JSON into your n8n instance Assign OpenAI API credentials to the "OpenAI Chat Model" node Assign Fal.ai HTTP Header Auth to the "Generate Music Track", "Check Generation Status", and "Fetch Final Result" nodes Activate the workflow—chat trigger will appear in your n8n chat interface Test by messaging: "Create an upbeat pop song about road trips" 🎯 Use Cases Content Creators: YouTubers generating custom jingles for videos on the fly, streamlining production from idea to audio export Educators: Music teachers using chat prompts to create era-specific folk tunes for classroom discussions, fostering interactive learning Gift Personalization: Friends crafting anniversary R&B tracks from shared memories via quick chats, delivering emotional audio surprises Artist Brainstorming: Songwriters prototyping hip-hop beats in real-time during sessions, accelerating collaboration and iteration ⚠️ Troubleshooting Invalid JSON from AI Agent: Ensure the system prompt stresses valid JSON; test the agent standalone with a sample query Music Generation Fails (401/403): Verify Fal.ai API key has minimax-music access; check usage quotas in dashboard Status Polling Loops Indefinitely: Bump wait time to 45-60s for complex tracks; inspect fal.ai queue logs for bottlenecks Lyrics Under 600 Characters: Tweak agent prompt to enforce fuller structures like [V1][C][V2][B][C]; verify output length in executions
Synchronizing WooCommerce inventory and creating products with Google Gemini AI and BrowserAct
Synchronize WooCommerce Inventory & Create Products with Gemini AI & BrowserAct This sophisticated n8n template automates WooCommerce inventory management by scraping supplier data, updating existing products, and intelligently creating new ones with AI-formatted descriptions. This workflow is essential for e-commerce operators, dropshippers, and inventory managers who need to ensure their product pricing and stock levels are synchronized with multiple third-party suppliers, minimizing overselling and maximizing profit. --- Self-Hosted Only This Workflow uses a community contribution and is designed and tested for self-hosted n8n instances only. --- How it works The workflow is typically run by a Schedule Trigger (though a Manual Trigger is also shown) to check stock automatically. It reads a list of suppliers and their inventory page URLs from a central Google Sheet. The workflow loops through each supplier: A BrowserAct node scrapes the current stock and price data from the supplier's inventory page. A Code node parses this bulk data into individual product items. It then loops through each individual product found. The workflow checks WooCommerce to see if the product already exists based on its name. If the product exists: It proceeds to update the existing product's price and stock quantity. If the product DOES NOT exist: An If node checks if the missing product's category matches a predefined type (optional filtering). If it passes the filter, a second BrowserAct workflow scrapes detailed product attributes from a dedicated product page (e.g., DigiKey). An AI Agent (Gemini) transforms these attributes into a specific, styled HTML table for the product description. Finally, the product is created in WooCommerce with all scraped details and the AI-generated description. Error Handling: Multiple Slack nodes are configured to alert your team immediately if any scraping task fails or if the product update/creation process encounters an issue. Note: This workflow does not support image uploads for new products. To enable this functionality, you must modify both the n8n and BrowserAct workflows. --- Requirements BrowserAct API account for web scraping BrowserAct n8n Community Node -> (n8n Nodes BrowserAct) BrowserAct templates named “WooCommerce Inventory & Stock Synchronization” and “WooCommerce Product Data Reconciliation” Google Sheets credentials for the supplier list WooCommerce credentials for product management Google Gemini account for the AI Agent Slack credentials for error alerts --- Need Help? How to Find Your BrowseAct API Key & Workflow ID How to Connect n8n to Browseract How to Use & Customize BrowserAct Templates How to Use the BrowserAct N8N Community Node --- Workflow Guidance and Showcase STOP Overselling! Auto-Sync WooCommerce Inventory from ANY Supplier
Tax deadline management & compliance alerts with GPT-4, Google Sheets & Slack
AI-Driven Tax Compliance & Deadline Management System Description Automate tax deadline monitoring with AI-powered insights. This workflow checks your tax calendar daily at 8 AM, uses GPT-4 to analyze upcoming deadlines across multiple jurisdictions, detects overdue and critical items, and sends intelligent alerts via email and Slack only when immediate action is required. Perfect for finance teams and accounting firms who need proactive compliance management without manual tracking. 🏛️🤖📊 Good to Know AI-Powered: GPT-4 provides risk assessment and strategic recommendations Multi-Jurisdiction: Handles Federal, State, and Local tax requirements automatically Smart Alerts: Only notifies executives when deadlines are overdue or critical (≤3 days) Priority Classification: Categorizes deadlines as Overdue, Critical, High, or Medium priority Dual Notifications: Critical alerts to leadership + daily summaries to team channel Complete Audit Trail: Logs all checks and deadlines to Google Sheets for compliance records How It Works Daily Trigger - Runs at 8:00 AM every morning Fetch Data - Pulls tax calendar and company configuration from Google Sheets Analyze Deadlines - Calculates days remaining, filters by jurisdiction/entity type, categorizes by priority AI Analysis - GPT-4 provides strategic insights and risk assessment on upcoming deadlines Smart Routing - Only sends alerts if overdue or critical deadlines exist Critical Alerts - HTML email to executives + Slack alert for urgent items Team Updates - Slack summary to finance channel with all upcoming deadlines Logging - Records compliance check results to Google Sheets for audit trail Requirements Google Sheets Structure Sheet 1: TaxCalendar DeadlineID | DeadlineName | DeadlineDate | Jurisdiction | Category | AssignedTo | IsActive FED-Q1 | Form 1120 Q1 | 2025-04-15 | Federal | Income | John Doe | TRUE Sheet 2: CompanyConfig (single row) Jurisdictions | EntityType | FiscalYearEnd Federal, California | Corporation | 12-31 Sheet 3: ComplianceLog (auto-populated) Date | AlertLevel | TotalUpcoming | CriticalCount | OverdueCount 2025-01-15 | HIGH | 12 | 3 | 1 Credentials Needed Google Sheets - Service Account OAuth2 OpenAI - API Key (GPT-4 access required) SMTP - Email account for sending alerts Slack - Bot Token with chat:write permission Setup Steps Import workflow JSON into n8n Add all 4 credentials Replace these placeholders: YOURTAXCALENDAR_ID - Tax calendar sheet ID YOURCONFIGID - Company config sheet ID YOURLOGID - Compliance log sheet ID C12345678 - Slack channel ID tax@company.com - Sender email cfo@company.com - Recipient email Share all sheets with Google service account email Invite Slack bot to channels Test workflow manually Activate the trigger Customizing This Workflow Change Alert Thresholds: Edit "Analyze Deadlines" node: Critical: Change <= 3 to <= 5 for 5-day warning High: Change <= 7 to <= 14 for 2-week notice Medium: Change <= 30 to <= 60 for 2-month lookout Adjust Schedule: Edit "Daily Tax Check" trigger: Change hour/minute for different run time Add multiple trigger times for tax season (8 AM, 2 PM, 6 PM) Add More Recipients: Edit "Send Email" node: To: cfo@company.com, director@company.com CC: accounting@company.com BCC: archive@company.com Customize Email Design: Edit "Format Email" node to change colors, add logo, or modify layout Add SMS Alerts: Insert Twilio node after "Is Critical" for emergency notifications Integrate Task Management: Add HTTP Request node to create tasks in Asana/Jira for critical deadlines Troubleshooting | Issue | Solution | |-------|----------| | No deadlines found | Check date format (YYYY-MM-DD) and IsActive = TRUE | | AI analysis failed | Verify OpenAI API key and account credits | | Email not sending | Test SMTP credentials and check if critical condition met | | Slack not posting | Invite bot to channel and verify channel ID format | | Permission denied | Share Google Sheets with service account email | 📞 Professional Services Need help with implementation or customization? Our team offers: 🎯 Custom workflow development 🏢 Enterprise deployment support 🎓 Team training sessions 🔧 Ongoing maintenance 📊 Custom reporting & dashboards 🔗 Additional API integrations Discover more workflows – Get in touch with us