IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Documents Java Discussion :

Export JTable vers Excel


Sujet :

Documents Java

  1. #1
    Membre du Club
    Femme Profil pro
    Ingénieur en Télécommunication
    Inscrit en
    Octobre 2017
    Messages
    121
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur en Télécommunication
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2017
    Messages : 121
    Points : 63
    Points
    63
    Par défaut Export JTable vers Excel
    Bonjour,

    je voudrais exporter une jtable verse excel, j'ai fait une recherche sur google et j'ai trouvé un code qui a résolu mon problème principale (export).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
     
    try {
                            HSSFWorkbook fWorkbook = new HSSFWorkbook();
                            HSSFSheet fSheet;
                            fSheet = fWorkbook.createSheet("new Sheet");
                            HSSFFont sheetTitleFont = fWorkbook.createFont();
                            File file = new File("C:\\Users\\tosiba\\Desktop\\projet\\Nabila\\liste.xls");        
     
                            HSSFCellStyle cellStyle = fWorkbook.createCellStyle();
                            sheetTitleFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
                            //sheetTitleFont.setColor();
                           TableModel model = table.getModel();
     
                           TableColumnModel model1 = table.getTableHeader().getColumnModel();
     
                            HSSFRow fRow1 = fSheet.createRow((short) 0);
                           for (int i = 0; i < model1.getColumnCount(); i++){
                                HSSFCell cell = fRow1.createCell((short) i);
                               cell.setCellValue(model1.getColumn(i).getHeaderValue().toString());           
     
                    }
                           for (int i = 1; i < model.getRowCount(); i++) {
                                HSSFRow fRow = fSheet.createRow((short) i);
                                for (int j = 0; j < model.getColumnCount(); j++) {
                                    HSSFCell cell = fRow.createCell((short) j);
                                   cell.setCellValue(Objects.toString(model.getValueAt(i, j), ""));
                                    cell.setCellStyle(cellStyle);
                                }
                            }
                            FileOutputStream fileOutputStream;
                            fileOutputStream = new FileOutputStream(file);
                            try (BufferedOutputStream bos = new BufferedOutputStream(fileOutputStream)) {
                                fWorkbook.write(bos);
                            }
                            fileOutputStream.close();
                        } catch (Exception e) {
                            e.printStackTrace();
    Dans le fichier excel, la premiére ligne de ma table n'est pas exporter c'est à dire,j'ai le header et les autres lignes sauf la premiére. j'ai essayé de changé l'indice de i=1 dans cette partie du code , mais en faisant ça le header n'apparait pas dans le fichier excel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for (int i = 1; i < model.getRowCount(); i++) {
                                HSSFRow fRow = fSheet.createRow((short) i);
                                for (int j = 0; j < model.getColumnCount(); j++) {
                                    HSSFCell cell = fRow.createCell((short) j);
                                   cell.setCellValue(Objects.toString(model.getValueAt(i, j), ""));
                                    cell.setCellStyle(cellStyle);
                                }
    Merci

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Il y a des données dans la ligne d'index 0 du modèle de la JTable à exporter, donc forcément si tu fais for (int i = 1; i < model.getRowCount(); i++) {, tu n'exportes pas les données de la première ligne.

    Il faut absolument faire for (int i = 0; i < model.getRowCount(); i++) {Maintenant, si ça écrase le header, c'est normal, parce que ensuite tu crées la ligne dans le sheet comme çà : HSSFRow fRow = fSheet.createRow((short) i);, en utilisant l'index i. Il suffit donc de décaler les lignes dans la feuille de calcul, tout simplement : HSSFRow fRow = fSheet.createRow((short) (i+1));
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre du Club
    Femme Profil pro
    Ingénieur en Télécommunication
    Inscrit en
    Octobre 2017
    Messages
    121
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur en Télécommunication
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2017
    Messages : 121
    Points : 63
    Points
    63
    Par défaut
    Je vous remercie

  4. #4
    Membre du Club
    Femme Profil pro
    Ingénieur en Télécommunication
    Inscrit en
    Octobre 2017
    Messages
    121
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur en Télécommunication
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2017
    Messages : 121
    Points : 63
    Points
    63
    Par défaut
    Bonsoir,
    Je rencontre un autre problème qui est le séléction de l'emplacement du fichier par l'utilisateur. c'est à dire pas toujours le même emplacement.
    Est ce que vous pouvez me donner un exemple ou bien des liens qui expliquent ça.
    Merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Export JTable vers "Excel" avec caractères accentués
    Par delphi_28 dans le forum Documents
    Réponses: 1
    Dernier message: 13/02/2016, 21h57
  2. Export Swing JTable vers Excel
    Par m3allem001 dans le forum Agents de placement/Fenêtres
    Réponses: 1
    Dernier message: 08/11/2013, 16h09
  3. exporter jtable vers excel
    Par papypolo22 dans le forum NetBeans
    Réponses: 15
    Dernier message: 06/12/2010, 12h13
  4. comment exporter les données d'un jtable vers excel
    Par papypolo22 dans le forum NetBeans
    Réponses: 3
    Dernier message: 23/11/2010, 19h13
  5. Exporter le contenu d'une JTable vers excel
    Par JAVIR dans le forum Composants
    Réponses: 2
    Dernier message: 01/09/2007, 19h19

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo