Plugin per ofxstatement per importare transazioni buoni pasto UpDay
Project description
Plugin UpDay per ofxstatement
Questo plugin per ofxstatement permette di importare automaticamente le transazioni dei buoni pasto UpDay dal sito day.it e convertirle nel formato OFX compatibile con software di contabilità come GnuCash.
ofxstatement è uno strumento per convertire estratti conto proprietari nel formato OFX standard.
Descrizione
UpDay è un'azienda italiana che si occupa della gestione di buoni pasto aziendali. Questo plugin automatizza il processo di estrazione e conversione dei movimenti dal portale web utilizzatori.day.it.
Funzionalità principali:
- Download automatico tramite web scraping del sito utilizzatori.day.it (comando
upday-download) - Salvataggio CSV per modifiche offline e riesportazioni successive
- Conversione OFX compatibile con software di contabilità (plugin ofxstatement)
- Gestione automatica della paginazione e navigazione del sito
- Validazione date con controllo del limite di 1 anno del sito
- Workflow in 2 fasi per separare download e conversione
Perché il web scraping?
Al momento UpDay non fornisce un sistema di esportazione diretta dei dati tramite file o API. Il web scraping è stato implementato come soluzione temporanea in attesa che l'azienda introduca metodi di esportazione più convenienti per gli utenti.
Requisiti di Sistema
Requisiti Obbligatori:
- Python 3.9 o superiore
- Google Chrome installato e aggiornato all'ultima versione (solo per il download da web)
- Account UpDay attivo su day.it (solo per il download da web)
- Connessione internet per il web scraping (solo fase di download)
Gestione ChromeDriver (Automatica):
Il comando upday-download gestisce automaticamente ChromeDriver con una strategia intelligente:
-
🔍 Prima priorità: Cerca ChromeDriver già installato localmente
- Homebrew (macOS):
/opt/homebrew/bin/chromedrivero/usr/local/bin/chromedriver - Sistema Linux:
/usr/bin/chromedriver - PATH di sistema: comando
chromedriver
- Homebrew (macOS):
-
🌐 Fallback automatico: Se ChromeDriver non è trovato localmente, tenta il download automatico
- ⚠️ Richiede connessione internet
- ⚠️ Può fallire per restrizioni di sistema, firewall aziendali, o politiche di sicurezza
- ✅ Una volta scaricato, viene memorizzato in cache per utilizzi futuri
-
🚨 Se il download automatico fallisce: Il programma fornisce istruzioni dettagliate per l'installazione manuale
Quando l'installazione automatica può fallire:
- Firewall aziendali che bloccano il download
- Politiche di sicurezza che impediscono l'esecuzione di binari scaricati
- Connessione internet assente durante il primo utilizzo
- Permessi insufficienti per scrivere nella cache
- Versioni di Chrome non supportate
Installazione
Installazione Semplice (Raccomandata)
pip install ofxstatement-upday
Questa installazione include:
- Il comando
upday-downloadper scaricare i dati dal web - Il plugin
updayper ofxstatement per convertire CSV in OFX - Tutte le dipendenze necessarie
Configurazione
Per modificare il file di configurazione, esegui:
ofxstatement edit-config
Si aprirà un editor vim con la configurazione attuale. Aggiungi la configurazione del plugin:
[upday]
plugin = upday
account = UPDAY_BUONI_PASTO
Parametri di configurazione:
upday: Nome della configurazione (puoi cambiarlo come preferisci)plugin: Deve essere sempre "upday"account: Nome dell'account per identificare le transazioni (default: UPDAY_BUONI_PASTO)
Nota: Puoi avere multiple configurazioni, basta aggiungere nuove sezioni con nomi diversi.
Utilizzo
Il plugin ora funziona in 2 fasi separate per maggiore flessibilità:
🌐 FASE 1: Download dei dati da web
Usa il comando upday-download per scaricare i dati dal sito UpDay e salvarli in CSV:
upday-download
Cosa succede:
- Il comando avvia automaticamente Chrome
- Ti chiede di inserire le date di inizio e fine
- Esegue il login automatico (o ti chiede di farlo manualmente se necessario)
- Scarica automaticamente tutte le transazioni dal sito UpDay
- Ti chiede il nome del file CSV dove salvare i dati
- Salva i dati nel file CSV specificato
Requisiti per questa fase:
- ✅ Connessione internet attiva
- ✅ Chrome e ChromeDriver funzionanti
- ✅ Account UpDay valido
Output: Un file CSV con tutte le transazioni estratte
📊 FASE 2: Conversione CSV → OFX
Usa ofxstatement per convertire il file CSV in formato OFX:
ofxstatement convert -t upday movimenti.csv upday.ofx
Cosa succede:
- Il plugin legge il file CSV
- Converte i dati nel formato OFX standard
- Salva il file OFX pronto per l'importazione
Requisiti per questa fase:
- ✅ Solo il file CSV (ottenuto dalla Fase 1)
- ❌ Nessuna connessione internet necessaria
- ❌ Nessun browser necessario
Output: Un file OFX pronto per GnuCash o altri software di contabilità
🎯 Esempio Completo: Workflow in 2 Fasi
# FASE 1: Scarica i dati da web
$ upday-download
Inserisci la data di inizio (formato gg/mm/aaaa): 01/09/2024
Inserisci la data di fine [se vuoto, usa oggi]: 30/09/2024
...
[il browser si apre e scarica i dati]
...
Inserisci il nome del file csv: settembre_2024
📄 File salvato: settembre_2024.csv
# FASE 2: Converti il CSV in OFX
$ ofxstatement convert -t upday settembre_2024.csv settembre_2024.ofx
✅ Conversione completata: settembre_2024.ofx
💡 Vantaggi del Workflow in 2 Fasi
- ✅ Modifiche manuali: Puoi modificare il CSV prima della conversione
- ✅ Riconversioni: Puoi riconvertire lo stesso CSV più volte senza riscaricare
- ✅ Backup: Hai sempre una copia dei dati grezzi in CSV
- ✅ Offline: La conversione funziona anche senza internet
- ✅ Automazione: Puoi automatizzare solo la fase di conversione negli script
🔄 Workflow Automatizzato
Per automatizzare entrambe le fasi in un unico script:
#!/bin/bash
# download_and_convert.sh
# Scarica i dati (interattivo)
upday-download
# Converti l'ultimo file CSV creato
ULTIMO_CSV=$(ls -t *.csv 2>/dev/null | head -1)
if [ -n "$ULTIMO_CSV" ]; then
OUTPUT_OFX="${ULTIMO_CSV%.csv}.ofx"
ofxstatement convert -t upday "$ULTIMO_CSV" "$OUTPUT_OFX"
echo "✅ Conversione completata: $OUTPUT_OFX"
else
echo "❌ Nessun file CSV trovato"
fi
📝 Formato del File CSV
Il file CSV generato da upday-download ha questa struttura:
data,ora,descrizione_operazione,tipo_operazione,numero_buoni,valore,luogo_utilizzo,indirizzo,codice_riferimento,pagina_origine
01/09/2024,12:30,Utilizzo buoni pasto,usage,1,-8.00,BAR CENTRALE,VIA ROMA 1 - MILANO,,1
05/09/2024,00:00,Accredito buoni pasto,credit,20,160.00,,,ABC123,1
Puoi modificare questo file manualmente prima della conversione in OFX.
Privacy e Sicurezza
- Nessuna memorizzazione credenziali: Il plugin non salva username o password
- Solo lettura: Accede solo in lettura ai dati delle transazioni
- Locale: Tutti i dati vengono elaborati localmente sul tuo computer
- Open source: Il codice è ispezionabile su GitHub
- Separazione dei compiti: Download e conversione sono separati per maggiore controllo
Installazione Manuale di ChromeDriver
Clicca per vedere le istruzioni per l'installazione manuale
Per evitare dipendenze dalla connessione internet durante l'uso:
macOS:
# Con Homebrew (raccomandato)
brew install chromedriver
# Rimuovi quarantena macOS
xattr -d com.apple.quarantine $(which chromedriver)
# Verifica installazione
chromedriver --version
Linux Ubuntu/Debian:
sudo apt-get update
sudo apt-get install chromium-chromedriver
# Verifica installazione
chromedriver --version
Linux altre distribuzioni:
# Scarica ChromeDriver compatibile con la tua versione di Chrome
wget https://chromedriver.chromium.org/downloads
# Estrai e sposta in /usr/bin/
sudo mv chromedriver /usr/bin/
sudo chmod +x /usr/bin/chromedriver
Windows:
- Scarica ChromeDriver da https://chromedriver.chromium.org
- Estrai il file
chromedriver.exe - Aggiungi la cartella al PATH di sistema
- Verifica: apri cmd e digita
chromedriver --version
Troubleshooting
Il comando upday-download non viene trovato
Dopo l'installazione, potrebbe essere necessario riavviare il terminale o ricaricare la configurazione:
# Bash
source ~/.bashrc
# Zsh
source ~/.zshrc
Se il problema persiste, verifica che pip installi i binari in una directory nel PATH:
pip show ofxstatement-upday
Errore "File non trovato" durante la conversione
Assicurati di:
- Aver eseguito prima
upday-download - Specificare il percorso corretto del file CSV
- Essere nella directory corretta
# Verifica che il file esista
ls -la *.csv
# Usa il percorso assoluto se necessario
ofxstatement convert -t upday /path/completo/file.csv output.ofx
ChromeDriver non funziona su macOS
macOS Gatekeeper può bloccare ChromeDriver. Risolvi con:
xattr -d com.apple.quarantine $(which chromedriver)
Sviluppo
Installazione da sorgenti per sviluppatori
git clone https://github.com/Alfystar/ofxstatement-upday.git
cd ofxstatement-upday
pip install -e .
Licenza
GPLv3 - Vedi il file LICENSE per i dettagli
Contributi
I contributi sono benvenuti! Per favore apri una issue o una pull request su GitHub.
Changelog
v1.1.0 (Prossima versione)
- ✨ BREAKING CHANGE: Separazione in 2 comandi distinti
upday-download: per scaricare i dati da web- Plugin ofxstatement: per convertire CSV in OFX
- ✅ Workflow più flessibile e manutenibile
- ✅ Possibilità di modificare il CSV prima della conversione
- ✅ Conversione offline senza bisogno di browser
v1.0.1
- Gestione automatica ChromeDriver
- Login automatico migliorato
- Validazione date
Autore
Alfystar - alfystar1701@gmail.com
Link Utili
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 ofxstatement_upday-1.1.1.tar.gz.
File metadata
- Download URL: ofxstatement_upday-1.1.1.tar.gz
- Upload date:
- Size: 47.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
abbf3f8f952354721f30f0ebb552e700d58b0f687e4f49f71702461aecfd92a9
|
|
| MD5 |
8e7a42c451ba9ce93bf369b63bca6c41
|
|
| BLAKE2b-256 |
844ae9047dc5f21926eb35e26f5b99c5b0bbe6ec365e83ed0f4e0a92898de50a
|
File details
Details for the file ofxstatement_upday-1.1.1-py3-none-any.whl.
File metadata
- Download URL: ofxstatement_upday-1.1.1-py3-none-any.whl
- Upload date:
- Size: 21.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e78dfb38d3b649a72a73ce74e7aa232c5152165f258a0d20a148fc0bae99bf3c
|
|
| MD5 |
e26fa3c3cfc2da24afb8a7000322d8de
|
|
| BLAKE2b-256 |
333d5a5c72a4e986e4e9acfc20e9ac8221d99a438000be5b5040fb04286e4d24
|