#!/usr/bin/env php bin/livre_recettes.csv // // en ouvrant le CSV, choisir le pipe | comme séparateur // chemins des dossiers et nom de la base require('src/files.php'); require('src/Config.php'); // lit le config.ini et gère certaines erreurs (exemple les / aux chemins manquants) Config::readFile('config/config.ini'); Config::hydrate(); // créer les dossiers si nécéssaire makeFolder(Config::$db_path); makeFolder(Config::$latex_path); makeFolder(Config::$pdf_path); //require 'src/model/doctrine-bootstrap.php'; require __DIR__ . '/../src/model/doctrine-bootstrap.php'; // chemin absolu // requête $date_debut = '2024-01-01'; $date_fin = '2024-12-31'; $debut = new DateTime($date_debut, new DateTimeZone('Europe/Paris')); $fin = new DateTime($date_fin, new DateTimeZone('Europe/Paris'));; $fin->setTime(23, 59, 59); $dql = 'SELECT n FROM Prestation n WHERE n.date >= :debut AND n.date <= :fin'; $bulk_data = $entityManager ->createQuery($dql) ->setParameter('debut', $debut->getTimestamp()) ->setParameter('fin', $fin->getTimestamp()) ->getResult(); // affichage echo "client|date|type|mode paiement|débours|total HT|salaire CESU|code presta\n"; foreach($bulk_data as $presta){ if($presta->getTypePresta() !== 'devis' && $presta->getTypePresta() !== 'non_vendue'){ $date = new DateTime()->setTimestamp($presta->getDate()); echo $presta->getClient()->getPrenomNom() . '|' . $date->format('d/m/Y') . '|' . $presta->getTypePresta() . '|' . $presta->getModePaiement() . '|'; if($presta->getTypePresta() === 'facture'){ echo $presta->getFacture()->getTotalPieces() . '|'; echo $presta->getFacture()->getTotalHT() . '||'; } elseif($presta->getTypePresta() === 'cesu'){ echo '||' . $presta->getCESU()->getSalaire() . '|'; } elseif($presta->getTypePresta() === 'location'){ echo '|' . (string)($presta->getLocation()->getLoyer() * (float)$presta->getLocation()->getLoyersPayes()) . '||'; } echo $presta->getCodePresta(); echo "\n"; } }