Skip to content

Instantly share code, notes, and snippets.

@tiois
Created January 28, 2015 14:33
Show Gist options
  • Select an option

  • Save tiois/5bc76c92e5ee13be0b05 to your computer and use it in GitHub Desktop.

Select an option

Save tiois/5bc76c92e5ee13be0b05 to your computer and use it in GitHub Desktop.
Export Excel and force download with phpoffice/phpexcel
/**
* Export the Abonnement list to Excel
*
* @param Request $request
* @return Response
*/
public function exportAction(Request $request)
{
$path = '../excel/abonnements.xls';
$file = new \SplFileObject($path, 'w');
$writer = new ExcelWriter($file, 'Abonnements au ' . date('Y-m-d'), 'Excel5');
$abonnements = $this->abonnementRepository->findActive();
$writer
->prepare()
->writeItem([
'Nom', 'Prénom', 'Courriel', 'Téléphone', 'Adresse', 'Ville', 'Code postal', 'Province', 'Pays',
'Fourchette d\'âge', 'Type de peau', 'Couleur de peau', 'Couleur des yeux', 'Types de cheveux',
'Nombre de points', 'Code de référence', 'Date d\'abonnement', 'Date de paiement', 'Type de paiement',
'# transaction Paypal'
]);
foreach($abonnements as $abonnement) {
/** @var Abonnement $abonnement */
$typesCheveux = [];
foreach($abonnement->getTypeCheveux() as $typeCheveux) {
$typesCheveux[] = $typeCheveux->__toString();
}
$typesCheveux = implode(', ', $typesCheveux);
$writer->writeItem([
$abonnement->getNom(), $abonnement->getPrenom(), $abonnement->getCourriel(), $abonnement->getTelephone(),
$abonnement->getAdresse(), $abonnement->getVille(), $abonnement->getCodePostal(), $abonnement->getProvince(),
$abonnement->getPays(), $abonnement->getFourchetteAge()->__toString(), $abonnement->getTypePeau()->__toString(),
$abonnement->getCouleurPeau()->__toString(), $abonnement->getCouleurYeux()->__toString(),
$typesCheveux, $abonnement->getPoints(), $abonnement->getHash(),
$abonnement->getCreatedAt()->format('Y-m-d H:i:s'),
$abonnement->getLastTransaction()->getPaymentDate()->format('Y-m-d H:i:s'),
$abonnement->getLastTransaction()->getPaypalTxnType(), $abonnement->getLastTransaction()->getPaypalTxnId()
]);
}
$writer->finish();
$response = new Response();
$response->headers->set('Content-Type', 'application/vnd.ms-excel');
$response->headers->set('Content-Disposition', 'attachment; filename="abonnement.xls"');
$response->headers->set('Pragma', "no-cache");
$response->headers->set('Expires', "0");
$response->headers->set('Content-Transfer-Encoding', "binary");
$response->headers->set('Content-Length', filesize($path));
$response->sendHeaders();
$response->setContent(readfile($path));
@unlink('../excel/abonnements.xls');
return $response;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment