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

Agents de placement/Fenêtres Java Discussion :

récuperer le contenu d'une JTable dans Un fichier excel


Sujet :

Agents de placement/Fenêtres Java

  1. #1
    Membre confirmé
    Inscrit en
    Octobre 2010
    Messages
    72
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 72
    Par défaut récuperer le contenu d'une JTable dans Un fichier excel
    salut;
    Mon probléme réside donc dans le fait de vouloir exporter le contenu d'une JTable dans un fichier excel.
    Aprés des heures de recherche j'ai su que la solution est JExcel mais ça m'était impossible d'appliquer le contenu du tutoriel

    http://www.andykhan.com/jexcelapi/tutorial.html

    qui est en anglais.

    J'ai trouvé plein de codes permettant de transporter le contenu d'un fichier excel vers JTable mais j'ai pas trouvé l'inverse.


    Enfin j'ai opté pour une solution intermédiaire qui est le code suivant:

    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
     
    import javax.swing.JFileChooser;
    import javax.swing.JLabel;
    import javax.swing.JOptionPane;
     
    import javax.swing.*;
     
    import java.awt.Color;
    import java.awt.Font;
    import java.io.*;
    public class Generation {
     
     
    	Choixrapport c= new Choixrapport ();
    	public ListeAdministrateurs l= new ListeAdministrateurs(c);
     
    	public Generation () { 
    		JLabel la=new JLabel("Le fichier a été bien enregistré dans l'emplacement spécifié ");
     
    		String A="Attention";
    		Font font = new Font("Verdana",Font.BOLD,15);	    
     
    	    la.setFont(font);
    	    la.setForeground(new Color(102,0,204));
     
     
    ;		JFileChooser chooser = new JFileChooser();
     
    		int state = chooser.showSaveDialog(null);
     
     
    		File file = chooser.getSelectedFile();
     
    		//String nameFile = "toto";
     
    		//create a new file
     
    			//FileOutputStream fileOut = new FileOutputStream(nameFile + ".xls");
     
     
     
    			if (file != null && state == JFileChooser.APPROVE_OPTION)
    		{
    			try
    			{
    				BufferedWriter bufferedWriter = new BufferedWriter(new FileWriter(file,true));
    				PrintWriter fileWriter = new PrintWriter(bufferedWriter);
     
    				for(int i=0; i<l.gett().getRowCount(); ++i)
    				{
    					for(int j=0; j<l.gett().getColumnCount(); ++j)
    					{
    						String s = l.gett().getValueAt(i,j).toString();
    						fileWriter.print(s);
     
    					}
    					fileWriter.println("");
     
    				}	
    				fileWriter.close();
     
     
    				JOptionPane.showMessageDialog(null, la, A, JOptionPane.INFORMATION_MESSAGE);
     
    			}catch(Exception e)
    			{
    				e.printStackTrace();
    				//JOptionPane.showMessageDialog(null, "Failure");
    			}
     
     
     
    		}
     
     
    	}
    }

    la génération du fichier s'effectue comme j'ai souhaité avec JFilechooser pour selectionner l'emplacement du nouveau fichier mais il me reste 2 grands problémes:


    1. Mon JTable initial contient 4 colonnes le contenu d'une ligne entiére est transféré dans une seule cellule du fichier généré si je mets ";" ou ","
    il s'affichent tels qu'ils sont ils ne se considérent pas comme séparateur


    2. Le format de fichier généré, c vrai qu'il s'ouvre avec excel mais c'est un format non connu si je clique dessus pour voir propriétés le typé est "fichier"
    pas d'extention

    s'il vous plait aidez moi à ce que mon fichier généré soit un fichier excel et que le contenu de chaque cellule de mon JTabe sera transféré dans une cellule à part de mon nouveau excel.

    Merci d'avance

  2. #2
    Expert confirmé
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Par défaut
    Comment dire. Un fichier Excel est une bestiole bieeeeeeeen plus compliquée qu'un simple fichier texte. De plus le fichier texte que tu génères ne ressemble à rien vu qu'il n'est pas basé sur un séparateur/délimiteur de colonne ou sur des colonnes de taille fixe.

    Je te conseille de fait de commencer par mettre un séparateur entre tes colonnes (comme ; ou encore |) et de lui donner comme extension csv, qui est un format qu'Excel sait comprendre.

    Toutefois si tu veux aller plus loin dans la génération d'une feuille de calcul, il te faudra passer par une API dédiée à la création de spreadsheets XLS comme JExcelApi, POI, JXLS ou d'autres. Toutefois, autant te prévenir, tu n'iras pas loin dans ta carrière de développeur sans pourvoir comprendre l'anglais. Arme toi d'un dictionnaire et au boulot.

  3. #3
    Membre confirmé
    Inscrit en
    Octobre 2010
    Messages
    72
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 72
    Par défaut
    Merci pour la réponse ansi que pour les précieux conseils

    La solution csv m'était trés efficace pour le moment je vous remercie reste que les noms des colonnes de mon JTable n'apparaissent pas, la premiére ligne de mon nouveau fichier CSV est la premiére ligne de mon JTable par contre je veux que la premiére ligne de mon fichier csv contient d'abord les noms de mes colonnes?

    Pourtant mes boucles 'for' commencent par '0

    J'éspére que je me suis bien éxprimée

  4. #4
    Expert confirmé
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Par défaut
    Tout simplement car les noms de colonnes ne font pas partie des données de la JTable.

    Il faut les écrire au préalable, en faisant une boucle du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    for (int i = 0; i< l.gett().getColumnCount(); i++) {
       fileWriter.print(l.gett().getColumnName(i));
       fileWriter.print(";");
    }
    fileWriter.println("");
    Avant d'ajouter les données.

  5. #5
    Membre confirmé
    Inscrit en
    Octobre 2010
    Messages
    72
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 72
    Par défaut résolu
    Merci c'est parfait.

  6. #6
    Membre averti
    Inscrit en
    Octobre 2010
    Messages
    45
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 45
    Par défaut
    j'ai le même problème sur l'exportation des données d'un jtable vers excel.
    en faite le jtable est remplit avec les données d'une DB mysql, j'ai sur mon interface un bouton de commande rnommé (exporter). peux tu m'aidé à exporter ces données vers le fichier excel ? merci d'avance.

  7. #7
    Membre averti
    Inscrit en
    Octobre 2010
    Messages
    45
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 45
    Par défaut
    stp je peux avoir plus d'information ta methode ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Choixrapport c = new Choixrapport();
       public ListeAdministrateurs adm = new ListeAdministrateurs(c);

  8. #8
    Membre confirmé
    Inscrit en
    Octobre 2010
    Messages
    72
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 72
    Par défaut
    Bonjour;

    ListeAdministrateurs c'est ma classe contenant mon JTable

    voila le code

    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    import java.awt.BorderLayout;
    import java.awt.Color;
    import java.awt.Dimension;
    import java.awt.Font;
    import java.awt.Toolkit;
    import java.awt.event.ActionEvent;
    import java.awt.event.ActionListener;
    import java.awt.event.KeyEvent;
    import java.awt.event.KeyListener;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.Statement;
    import java.util.Vector;
     
    import javax.swing.BorderFactory;
    import javax.swing.Box;
    import javax.swing.ImageIcon;
    import javax.swing.JButton;
    import javax.swing.JFrame;
    import javax.swing.JLabel;
    import javax.swing.JPanel;
    import javax.swing.JScrollPane;
    import javax.swing.JTable;
    import javax.swing.JTextField;
     
    //class pour afficher la liste des administrateur disponible
    public class ListeAdministrateurs extends JFrame implements ActionListener,KeyListener
    {
    	private static final long serialVersionUID = -4902442320396426081L;
    	JTable table;//instancition de JTable pour le remplissage des données a partir de la BD
    	Statement statement;//creation du statement à partir de la chaine de connexion pour commner les requetes
    	ResultSet resultRequete;//conteneur la resultat de la requete excutée
    	//constructeur de la class
    	@SuppressWarnings("static-access")
    	private JTextField mois = null;
    	private JTextField année = null;
    	private JButton v= new JButton();
    	JButton r= new JButton();
     
     
    	public ListeAdministrateurs(Choixrapport c)
    	{ v.addKeyListener(this);
        r.addKeyListener(this);
        v.addActionListener(this);
        r.addActionListener(this);
    	//ImageIcon ko = new ImageIcon("imprimer-icone-6467-48.png");
        ImageIcon ko = new ImageIcon("disque-sauvegardez-icone-5538-48.png");
        v.setIcon(ko);
        v.setBackground(Color.WHITE);
        v.setBorderPainted(false);
     
     
        ImageIcon koo = new ImageIcon("ko.png");
        r.setIcon(koo);
        r.setBackground(Color.WHITE);
        r.setBorderPainted(false);
     
     
    		Font font = new Font("Comic Sans Ms",Font.BOLD,13);
    	Font fontj = new Font("Comic Sans Ms",Font.BOLD,15);
    		JPanel a = new JPanel();
    		JPanel b = new JPanel();
    		JPanel panel = new JPanel();
    		a.setBackground(new Color(255,255,255));
    		b.setBackground(new Color(255,255,255));
    		    mois = new JTextField(4);
    		    mois.setMaximumSize(mois.getPreferredSize());
    		    mois.setText(c.getMois());
    		    mois.setFont(fontj);
    		    mois.setBorder(BorderFactory.createLineBorder(Color.white));
    		    mois.setEditable(false);
    		    mois.setBackground(Color.white);
     
    		    année = new JTextField(6);
    		    année.setMaximumSize(mois.getPreferredSize());
    		    année.setText(c.getAnnee());
    		    année.setFont(fontj);
    		    année.setBorder(BorderFactory.createLineBorder(Color.white));
    		    année.setEditable(false);
    		    année.setBackground(Color.white);
     
    		    JLabel moiss= new JLabel("Mois:");
    			moiss.setFont(fontj);
     
    			JLabel anns= new JLabel("Année:");
    			anns.setFont(fontj);
     
    			Box inv = Box.createHorizontalBox(); 
    			inv.add(Box.createHorizontalStrut(15)); 
    		   	inv.add(moiss); 
    		    inv.add(mois);
     
    		    inv.add(anns); 
    		    inv.add(année);
     
    			Box boutounet = Box.createHorizontalBox(); 
    		   	boutounet.add(v); 
    		   	boutounet.add(Box.createHorizontalStrut(30)); 
    		   	boutounet.add(r);
     
    	        JLabel ADS= new JLabel("Rapport mensuel");
    	        Font fontm = new Font("Monotype Corsiva",Font.BOLD,30);
    		    ADS.setFont(fontm);	
    		    ADS.setForeground(new Color(0,51,255));
     
    		    Box ads = Box.createHorizontalBox(); 
    			ads.add(ADS); 
     
    		 panel.setBackground(new Color(255,255,255));	
    		// Le composant JTable
    	     JTable table = remplirTable();//la table sera initialisée par la liste des administrateurs envoyée par la fct 'remplirTable()'
     
    	     table.setPreferredScrollableViewportSize(new Dimension(500,145));//prendre la dimension de la table
    	     table.setFont(font);
     
    	     table.getColumnModel().getColumn(3).setCellRenderer(new MyCellRenderer());
    	     table.getTableHeader().setFont(new Font("Comic Sans Ms",Font.BOLD,15));
    	     table.getTableHeader().setForeground(new Color(0,51,255));
    	    table.getTableHeader().setBackground(new Color(255,255,255));
    	    // table.setForeground(new Color(0,51,255));
    	     // Un panneau, placé dans la fenêtre
    	     JScrollPane panneau = new JScrollPane(table);//mettre la table dans ascenceur
    	     panneau.setBackground(new Color(255,255,255));
    	     table.setBackground(new Color(255,255,255));
     
     
    	     panel.add(a, BorderLayout.CENTER);//centraliser le panneau dans la fenetre
    	     panel.add(panneau, BorderLayout.CENTER);//centraliser le panneau dans la fenetre
    	     panel.add(b, BorderLayout.CENTER);//centraliser le panneau dans la fenetre
     
    	     Box g1= Box.createVerticalBox();
     
    		    g1.add(Box.createVerticalStrut(70)); 
    		    g1.add(boutounet);
    		   // g1.add(Box.createVerticalStrut(20)); 
     
    		    b.add(g1);
     
    		  	Box g= Box.createVerticalBox();
    		    g.add(ads);
    		    g.add(Box.createVerticalStrut(20)); 
    		    g.add(inv);
    		    g.add(Box.createVerticalStrut(40)); 
     
    		    a.add(g);
     
    	        this.setContentPane(panel);
    		    this.setTitle("rapport mensuel");
    	        this.pack();
    	        this.setVisible(true);
    	        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    		    this.setVisible(true);
    		    this.setSize(570,500);
    		    Dimension dim = Toolkit.getDefaultToolkit().getScreenSize();
    		    this.setLocation(dim.width/2 - this.getWidth()/2, dim.height/2 - this.getHeight()/2);
    		    ImageIcon i = new ImageIcon("new.jpeg");
    		    this.setIconImage(i.getImage());
    	}
     
    	/** Requête et résultats dans une JTable */
    	@SuppressWarnings("unchecked")
    	JTable remplirTable() {
    	      Vector tabLignes=new Vector(), nomCols=new Vector();
    	      int i;
    	      try {
     
    	        String requeteMysql = "Select * From rapport";//chaine contenant la requete a executée
    	        statement = (Statement) new Configuration().connexion.createStatement();//creation du statement a partir de la chaine de connexion qui est placée dans la classe de connexion au MYsql
    			resultRequete = (ResultSet) statement.executeQuery(requeteMysql);//excuter la requete et la mettre dans une variabale ResulatSet 
    	        // Extraire noms des colonnes; les placer dans Vector nomCols
    	        ResultSetMetaData md = resultRequete.getMetaData();
    	        nomCols = new Vector();
    	        for( i=1; i<=md.getColumnCount (); i++)
    	             nomCols.add( md.getColumnLabel(i));
     
     
    	        // Mémoriser le résultat dans la JTable
    	        while( resultRequete.next()) {
    	         //placer les valeurs dans Vector ligne
    	           Vector ligne=new Vector();
     
    	           //le 3 designe le nombre de colonnes qui doit etre connu dans la table
    	           for(i=1; i<=4; i++) 
    	           {
    	               String ch=resultRequete.getString(i);
    	               ligne.add(ch);
     
    	           }
    	           tabLignes.add(ligne);
    	         }
     
    	       }
    	     catch(Exception e) { 
    	         System.out.print("erreur1 "+e.getMessage());//récuperer le message d'erreur en cas d'erreur
    	     }
     
    	     return new JTable(tabLignes,nomCols);//type de retour qui initialise le JTable par la liste des vecteur envoyées remplis des tables
    	}
     
    	public JTable gett()
    	{return this.remplirTable();}
     
    	  public void actionPerformed(ActionEvent e) { 
    	       if(e.getSource()==v)
    	    	{
     
    	    	   new  Generation ();
     
    		     this.dispose();
    		    }
    	       else
    	       {
    	    	   if(e.getSource()==r)
    	       	{   
    	   	     new  Majouconsult();
    	   	     this.dispose();
    	   	    }
    	       }
    	      }
    	  public void keyTyped(KeyEvent e){}
    	  public void keyPressed(KeyEvent e){}
    		 public void keyReleased(KeyEvent e){
    	  if(e.getKeyCode() == KeyEvent.VK_ENTER)
     
    		 {   if (e.getSource()== v)
    			 {new Generation (); 
    	         this.dispose(); }
     
    		 	 else 
     
    		 	  if (e.getSource()== r)
    		 	 	{ new Majouconsult();
    		   	     this.dispose(); } 
     
    		 	}}
     
    	    }
    Je crois que vous n'aurez besoin que de la methode remplirTable()

    n'hésitez pas à poser d'autres questions si votre prbléme persistera

    bonne chance et bonne journée

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

Discussions similaires

  1. Extraire le contenu d'une cellule dans un fichier excel
    Par JuniorBI dans le forum Développement de jobs
    Réponses: 2
    Dernier message: 28/09/2010, 12h03
  2. [XL-2003] Récupérer le contenu d'une ligne dans un fichier excel (rapidement)
    Par kigrez dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 12/04/2010, 21h20
  3. Réponses: 1
    Dernier message: 10/04/2010, 07h16
  4. mettre le contenu d'une liste dans un fichier EXCEL
    Par john_wili dans le forum Jasper
    Réponses: 1
    Dernier message: 13/01/2009, 11h22
  5. Afficher le contenu d'une Hashtable dans un fichier Excel
    Par decoalaa dans le forum Windows Forms
    Réponses: 2
    Dernier message: 24/11/2008, 15h10

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