watch-my-money

Analyze bank transactions, categorize spending, track monthly budgets, detect overspending and anomalies. Outputs interactive HTML report.

7 stars

Best use case

watch-my-money is best used when you need a repeatable AI agent workflow instead of a one-off prompt.

Analyze bank transactions, categorize spending, track monthly budgets, detect overspending and anomalies. Outputs interactive HTML report.

Teams using watch-my-money should expect a more consistent output, faster repeated execution, less prompt rewriting.

When to use this skill

  • You want a reusable workflow that can be run more than once with consistent structure.

When not to use this skill

  • You only need a quick one-off answer and do not need a reusable workflow.
  • You cannot install or maintain the underlying files, dependencies, or repository context.

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/watch-my-money/SKILL.md --create-dirs "https://raw.githubusercontent.com/Demerzels-lab/elsamultiskillagent/main/public/skills/andreolf/watch-my-money/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/watch-my-money/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How watch-my-money Compares

Feature / Agentwatch-my-moneyStandard Approach
Platform SupportNot specifiedLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

Analyze bank transactions, categorize spending, track monthly budgets, detect overspending and anomalies. Outputs interactive HTML report.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

SKILL.md Source

# watch-my-money

Analyze transactions, categorize spending, track budgets, flag overspending.

## Workflow

### 1. Get Transactions

Ask user for bank/card CSV export OR pasted text.

Common sources:
- Download CSV from your bank's online portal
- Export from budgeting apps
- Copy/paste transactions from statements

Supported formats:
- Any CSV with date, description, amount columns
- Pasted text: "2026-01-03 Starbucks -5.40 CHF"

### 2. Parse & Normalize

Read input, normalize to standard format:
- Auto-detect delimiter (comma, semicolon, tab)
- Parse dates (YYYY-MM-DD, DD/MM/YYYY, MM/DD/YYYY)
- Normalize amounts (expenses negative, income positive)
- Extract merchant from description
- Detect recurring transactions (subscriptions)

### 3. Categorize Transactions

For each transaction, assign category:

**Categories:**
- rent, utilities, subscriptions, groceries, eating_out
- transport, travel, shopping, health
- income, transfers, other

Categorization order:
1. Check saved merchant overrides
2. Apply deterministic keyword rules (see [common-merchants.md](references/common-merchants.md))
3. Pattern matching (subscriptions, utilities)
4. Heuristic fallback

For ambiguous merchants (batch of 5-10), ask user to confirm.
Save overrides for future runs.

### 4. Check Budgets

Compare spending against user-defined budgets.

Alert thresholds:
- 80% - approaching limit (yellow)
- 100% - at limit (red)
- 120% - over budget (red, urgent)

See [budget-templates.md](references/budget-templates.md) for suggested budgets.

### 5. Detect Anomalies

Flag unusual spending:
- Category spike: spend > 1.5x baseline AND delta > 50
- Subscription growth: subscriptions up > 20%
- New expensive merchant: first appearance AND spend > 30
- Potential subscriptions: recurring same-amount charges

Baseline = previous 3 months average (or current month if no history).

### 6. Generate HTML Report

Create local HTML file with:
- Month summary (income, expenses, net)
- Category breakdown with budget status
- Top merchants
- Alerts section
- Recurring transactions detected
- Privacy toggle (blur amounts/merchants)

Copy [template.html](assets/template.html) and inject data.

### 7. Save State

Persist to `~/.watch_my_money/`:
- `state.json` - budgets, merchant overrides, history
- `reports/YYYY-MM.json` - machine-readable monthly data
- `reports/YYYY-MM.html` - interactive report

## CLI Commands

```bash
# Analyze CSV
python -m watch_my_money analyze --csv path/to/file.csv --month 2026-01

# Analyze from stdin
cat transactions.txt | python -m watch_my_money analyze --stdin --month 2026-01 --default-currency CHF

# Compare months
python -m watch_my_money compare --months 2026-01 2025-12

# Set budget
python -m watch_my_money set-budget --category groceries --amount 500 --currency CHF

# View budgets
python -m watch_my_money budgets

# Export month data
python -m watch_my_money export --month 2026-01 --out summary.json

# Reset all state
python -m watch_my_money reset-state
```

## Output Structure

Console shows:
- Month summary with income/expenses/net
- Category table with spend vs budget
- Recurring transactions detected
- Top 5 merchants
- Alerts as bullet points

Files written:
- `~/.watch_my_money/state.json`
- `~/.watch_my_money/reports/2026-01.json`
- `~/.watch_my_money/reports/2026-01.html`

## HTML Report Features

- Collapsible category sections
- Budget progress bars
- Recurring transaction list
- Month-over-month comparison
- Privacy toggle (blur sensitive data)
- Dark mode (respects system preference)
- Floating action button
- Screenshot-friendly layout
- Auto-hide empty sections

## Privacy

All data stays local. No network calls. No external APIs.
Transaction data is analyzed locally and stored only in `~/.watch_my_money/`.

Related Skills

video-watcher

7
from Demerzels-lab/elsamultiskillagent

Analyze video content by extracting frames at regular intervals.

portfolio-watcher

7
from Demerzels-lab/elsamultiskillagent

Monitor stock/crypto holdings, get price alerts, track portfolio performance

copilot-money

7
from Demerzels-lab/elsamultiskillagent

Query Copilot Money personal finance data (accounts, transactions, net worth, holdings, asset allocation) and refresh bank connections. Use when the user asks about finances, account balances, recent transactions, net worth, investment allocation, or wants to sync/refresh bank data.

sec-filing-watcher

7
from Demerzels-lab/elsamultiskillagent

Monitor SEC EDGAR for new filings and get Telegram/Slack summaries via Clawdbot. Use when setting up SEC filing alerts, adding/removing tickers to monitor, configuring form types, starting/stopping the watcher, or troubleshooting filing notifications.

camera-watch

7
from Demerzels-lab/elsamultiskillagent

YOLOv8-based camera surveillance with object detection. Works with any IP camera supporting RTSP streams or HTTP snapshots (Hikvision, Dahua, Reolink, Amcrest, Unifi, and more). Detects 80+ object types (person, car, dog, etc.) and sends notifications with snapshots. Use for motion detection, night watch routines, or security monitoring.

Trend Watcher Tool

7
from Demerzels-lab/elsamultiskillagent

Monitors GitHub Trending and tech communities for emerging tools and technologies.

skill-liewatch

7
from Demerzels-lab/elsamultiskillagent

Play the LIE.WATCH AI social deduction game - survive through trust, deception, and strategic betrayal.

liewatch

7
from Demerzels-lab/elsamultiskillagent

Play the LIE.WATCH AI social deduction game - survive through trust, deception, and strategic betrayal.

agent-money-tracker

7
from Demerzels-lab/elsamultiskillagent

Intelligent budget tracking and financial management library for AI agents - expense tracking, income management, budgets, savings goals, and LLM-powered insights

abby-watch

7
from Demerzels-lab/elsamultiskillagent

Simple time display for Abby.

bilibili-youtube-watcher

7
from Demerzels-lab/elsamultiskillagent

Fetch and read transcripts from YouTube and Bilibili videos.

process-watch

7
from Demerzels-lab/elsamultiskillagent

Monitor system processes - CPU, memory, disk I/O, network, open files, ports. Find resource hogs, kill runaway processes, track what's consuming your machine.