Files
2026-06-09 18:40:21 +02:00

6.0 KiB


title: ExpenseOwl created: 2026-06-07 updated: 2026-06-07 type: app tags: [catalogue, budgeting, python, flask, minimaliste, depenses, simple] confidence: high contested: false sources: [https://selfh.st/apps/?tag=budgeting, https://github.com/nicholasgasior/expenseowl, https://expenseowl.com/]

ExpenseOwl 🦉

Suivi de dépenses ultra-minimaliste écrit en Python/Flask. Pour qui veut juste noter ses dépenses sans se prendre la tête avec des catégories complexes, des budgets ou de l'import bancaire.

Métadonnée Valeur
Site web https://expenseowl.com/
GitHub https://github.com/nicholasgasior/expenseowl
License MIT
Langage Python (Flask)
Étoiles 133
Dernière MAJ 2026-05-10
Catégorie cat-budgeting

Description

ExpenseOwl est une application web volontairement minimaliste de suivi de dépenses personnelles. Son auteur assume : pas d'import bancaire, pas de catégorisation avancée, pas de budgets, pas d'API riche. Juste créer une dépense, la visualiser, la supprimer. Parfait pour qui veut commencer à suivre ses dépenses sans la complexité d'un Firefly III.

Les fonctionnalités essentielles : dépenses avec date, montant, description courte, catégories simples (alimentation, logement, transport, loisirs, santé, etc. — personnalisables), revenus (séparés des dépenses), tableau de bord avec totaux par mois, graphique simple (revenus vs dépenses par mois), filtres par période/catégorie, multi-utilisateurs optionnel (admin peut créer des comptes invités). Et c'est tout. L'interface est claire, sans fioritures, et l'ajout d'une dépense prend littéralement 5 secondes.

La stack technique est volontairement légère : Flask (microframework Python), SQLite par défaut (parfait pour un usage mono-utilisateur), templates Jinja2 rendus côté serveur, Chart.js pour les graphiques. Pas de SPA, pas de build, pas de npm. L'image Docker fait moins de 100 Mo et l'app démarre en 2 secondes. Idéal pour un Raspberry Pi ou un serveur modeste.

ExpenseOwl est l'anti-Firefly III : là où Firefly vise l'exhaustivité fonctionnelle, ExpenseOwl vise la simplicité radicale. Pour 80% des gens qui veulent juste savoir "combien j'ai dépensé ce mois-ci", c'est largement suffisant.

Installation

Via Docker (recommandé)

# docker-compose.yml
services:
  expenseowl:
    image: ghcr.io/nicholasgasior/expenseowl:latest
    container_name: expenseowl
    restart: unless-stopped
    ports:
      - "5000:5000"
    environment:
      - SECRET_KEY=Change...et
      - DATABASE_URL=sqlite:////data/expenses.db
      - ALLOW_REGISTRATION=false
    volumes:
      - expenseowl-data:/data
    healthcheck:
      test: ["CMD", "wget", "--spider", "-q", "http://localhost:5000/"]
      interval: 30s
      timeout: 10s
      retries: 3

volumes:
  expenseowl-data:

⚠️ Vérifier le tag exact sur le GHCR.

Installation manuelle (Python)

  1. Pré-requis : Python 3.10+, pip, SQLite (inclus dans Python).
  2. git clone https://github.com/nicholasgasior/expenseowl.git && cd expenseowl
  3. pip install -r requirements.txt
  4. Configurer variables d'environnement (SECRET_KEY, DATABASE_URL).
  5. Initialiser la DB : flask db upgrade (ou python app.py init selon la version).
  6. python app.py (dev) ou via Gunicorn/uWSGI (prod).
  7. Reverse proxy Nginx/Caddy en front.

Configuration

  • Premier lancement : créer le compte admin via l'UI.
  • ALLOW_REGISTRATION=false : recommandé en production (créer manuellement les comptes).
  • Catégories : par défaut une liste de base, personnalisable depuis l'UI.
  • Devise : configurée au niveau global, pas de multi-devise native.
  • PWA : ExpenseOwl peut s'installer comme Progressive Web App sur mobile (ajout à l'écran d'accueil).
  • HTTPS : obligatoire via reverse proxy.
  • Backup : copier le fichier expenses.db régulièrement (cron + rclone).

Alternatives

Open Source

  • app-spliit — partage entre amis (multi-utilisateurs natif)
  • app-actual-budget — budgeting complet, plus puissant
  • app-firefly-iii — référence, mais complexe
  • app-ocular — autre option TypeScript minimaliste
  • Wallet / Paisa / MyExpenses — alternatives Android natives
  • GnuCash — comptabilité double-partie, plus puissant
  • Skrooge / KMyMoney — gestion budget KDE/GNOME

Propriétaires

  • Wallet by BudgetBakers — app mobile tchèque
  • Money Manager / Money Lover — apps mobiles grand public
  • Spendee — freemium avec agrégation bancaire
  • PocketGuard — mobile-first US

Sécurité

  • HTTPS obligatoire via reverse proxy (Traefik/Caddy).
  • SECRET_KEY : token Flask pour les sessions — générer aléatoirement (32+ caractères), ne jamais commit dans Git.
  • ALLOW_REGISTRATION=false en prod : créer les comptes via admin uniquement.
  • SQLite : sécuriser les permissions (chmod 600) sur le fichier DB et le volume.
  • Backups 3-2-1 : copier régulièrement le fichier expenses.db vers stockage chiffré.
  • Updates : suivre les releases GitHub, le projet est actif mais les releases sont irrégulières.
  • 2FA : non natif, compter sur le reverse proxy (Authelia/Authentik) pour durcir l'accès admin.
  • Logs : Flask logs standards, à monitorer via Grafana/Loki ou équivalent.

Ressources

Pages Liées