Afficher un tableau au format .csv dans un article

All contributions published for previous SPIP versions

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

    Reply to this message

  • 1

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

    Reply to this message

Add a comment

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 / PostgreSQL
  • 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 apparait.

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.

Who are you?
[Log in]

To show your avatar with your message, register it first on gravatar.com (free et painless) and don’t forget to indicate your Email addresse here.

Enter your comment here

This form accepts SPIP shortcuts {{bold}} {italic} -*list [text->url] <quote> <code> and HTML code <q> <del> <ins>. To create paragraphs, just leave empty lines.

Add a document

Follow the comments: RSS 2.0 | Atom