Afficher un tableau au format .csv dans un article

Ceci est une ARCHIVE, peut-être périmée. Vérifiez bien les compatibilités !

Création d’un filtre permettant l’affichage d’un tableau excel (par exemple)

Ce filtre est conçu pour afficher un tableau sauvegardé au format csv, avec séparateur ’ ;’ (OpenOffice, Excel, Notepad...)

Le tableau est affiché à la place de(s) icone(s) représentant le ou les fichiers joints à l’article.

Cette contribution est inspirée d’un article publié dans .NET de février 2006.

1. Ajouter un type de document

Il faut suivre la procédure décrite dans l’article correspondant sur www.spip.net

Il faudra retenir les valeurs suivantes :

  1. titre : CSV
  2. extension : csv
  3. inclus : embed
  4. upload : oui

Par ftp, créer un répertoire csv dans /IMG/

2. Ajouter le code suivant dans mes_fonctions.php3

/*  Affichage d'un tableau Excel  */

function tableur($classeur){
$fichier = $classeur;
$fic = fopen($fichier, 'rb');
$result = "<table border='1'>\n";
for ($ligne = fgetcsv($fic, 1024,";"); !feof($fic); $ligne = fgetcsv($fic, 1024,";")) {
	$result = $result."<tr>\n";
	$j = sizeof($ligne);
	for ($i = 0; $i < $j; $i++) {
		$result = $result."<td>$ligne[$i]</td>\n";
	}
	$result = $result."</tr>\n";
}
$result = $result."</table>\n";
return $result;

}

3. Boucle

	<BOUCLE_documentsCSV(DOCUMENTS){id_article}{par num titre}{mode=document}{doublons}{extension=csv}>
	<dt>[(#URL_DOCUMENT|tableur)]</dt>
	<div class="clear">&nbsp;</div>
	</BOUCLE_documentsCSV>

4. Mise en forme

Elle reste à faire.

Jacques J.

liste Spip-lyon[at]rezo.net

Discussion

2 discussions

  • 3

    Sauf erreur de ma part (il me semble avoir suivi scrupuleusement la manip décrite), j’ai immanquablement une réponse « filtre tableur non défini »
    J’ai beau mettre le fichier mes_fonctions.php dans le dossier squelettes, à la racine... rien n’y fait.
    Y’a pas autre chose à faire qui ne serait pas mentionné ?

    Version de spip 1.9.1 [7502]

    • Bonjour,

      Cette contrib écrite pour spip 1.72 et 1.8x n’est peut-être pas compatible avec 1.9x
      Je te conseille de regarder la contrib suivante (aussi pour 1.8x) qui est peut-être adaptable pour 1.9x.

      D’une manière générale depuis la version 1.9, il est conseillé de regarder si un plugin ne fait pas ce que tu souhaites :
      Surcontrib.net
      Surspip-zone à télécharger.

      Merci du retour.

    • Sisi ça marche très bien avec Spip 1.9.1 et un fichier CSV généré par OpenOffice. L’erreur doit venir d’ailleurs ;-)

    • Pour 1.9x, il est intéressant de regarder ce que propose marabbeh enutilisant les modèles.

      Amicalement

    Répondre à ce message

  • 1

    Ne faut-il pas ajouter aussi dans spip_types_documents : mime_type = application/csv-tab-delimited-table ?

    Répondre à ce message

Ajouter un commentaire

Avant de faire part d’un problème sur un plugin X, merci de lire ce qui suit :

  • Désactiver tous les plugins que vous ne voulez pas tester afin de vous assurer que le bug vient bien du plugin X. Cela vous évitera d’écrire sur le forum d’une contribution qui n’est finalement pas en cause.
  • Cherchez et notez les numéros de version de tout ce qui est en place au moment du test :
    • version de SPIP, en bas de la partie privée
    • version du plugin testé et des éventuels plugins nécessités
    • version de PHP (exec=info en partie privée)
    • version de MySQL / SQLite
  • Si votre problème concerne la partie publique de votre site, donnez une URL où le bug est visible, pour que les gens puissent voir par eux-mêmes.
  • En cas de page blanche, merci d’activer l’affichage des erreurs, et d’indiquer ensuite l’erreur qui apparaît.

Merci d’avance pour les personnes qui vous aideront !

Par ailleurs, n’oubliez pas que les contributeurs et contributrices ont une vie en dehors de SPIP.

Qui êtes-vous ?
[Se connecter]

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom