Editer JTable contenant des entiers
Résolu
encours
Messages postés
121
Date d'inscription
Statut
Membre
Dernière intervention
-
encours Messages postés 121 Date d'inscription Statut Membre Dernière intervention -
encours Messages postés 121 Date d'inscription Statut Membre Dernière intervention -
bonjour,
j'utilise un JTable qui contient des doubles et des entiers et ....
alors pour laisser l'utilisateur modifier un entier dans la table j'appele une classe IntegerEditor(int, int) pour s'assurer qu'il a entrer un integer => ca marche bien
Code Java :
table.setDefaultEditor(Integer.class, new IntegerEditor(1, 100000));
alors j'ai voulu faire de meme pour les colonnes des doubles de la table : j'ai essayé de convertir cette classe pour qu'elles soit pour les double mais ca rester comme elle est
est ce que vous pouvez me convertir cette classe pour qu'elle fait le meme chose mais pour les doubles
voici le lien
Code :
http://www.javafr.com/codes/EDITER-TABLE-CONTENANT-ENTIERS_53508.aspx
merci pour votre aide
j'utilise un JTable qui contient des doubles et des entiers et ....
alors pour laisser l'utilisateur modifier un entier dans la table j'appele une classe IntegerEditor(int, int) pour s'assurer qu'il a entrer un integer => ca marche bien
Code Java :
table.setDefaultEditor(Integer.class, new IntegerEditor(1, 100000));
alors j'ai voulu faire de meme pour les colonnes des doubles de la table : j'ai essayé de convertir cette classe pour qu'elles soit pour les double mais ca rester comme elle est
est ce que vous pouvez me convertir cette classe pour qu'elle fait le meme chose mais pour les doubles
voici le lien
Code :
http://www.javafr.com/codes/EDITER-TABLE-CONTENANT-ENTIERS_53508.aspx
merci pour votre aide
A voir également:
- Editer JTable contenant des entiers
- Excel sélectionner toutes les lignes contenant un mot ✓ - Forum Excel
- Editer un pdf - Guide
- Paramètrez la messagerie électronique ci-dessous pour ranger automatiquement dans le dossier famille les courriers envoyés par tonton@pixmail.org contenant le mot cousin. - Forum Mail
- Sur instagram, masquer automatiquement les commentaires contenant son surnom, "baleine". - Forum Facebook
- Gaston a entièrement vidé la corbeille de son ordinateur qui contenait pourtant des documents importants. il ne possède aucune sauvegarde de son ordinateur. nommez un logiciel qu'il peut utiliser pour tenter de retrouver ses documents ✓ - Forum Bureautique
6 réponses
Lien mort comme on dit ^^
Postes directement le code AVEC LES BALISES DE CODE (à côté de gras, italique et souligné) c'est plus simple.
Postes directement le code AVEC LES BALISES DE CODE (à côté de gras, italique et souligné) c'est plus simple.
voici le code
je suis urgent si vous pouvez m'aidez d'avantage
merci bien
if (answer == 1) { //Revert!
ftf.setValue(ftf.getValue());
return true;
}
return false;
}
}
</code>
et l'appel ca se fait comme ca
je suis urgent si vous pouvez m'aidez d'avantage
merci bien
import javax.swing.AbstractAction; import javax.swing.DefaultCellEditor; import javax.swing.JFormattedTextField; import javax.swing.JOptionPane; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.KeyStroke; import javax.swing.SwingUtilities; import java.awt.event.ActionEvent; import java.awt.event.KeyEvent; import java.awt.Component; import java.awt.Toolkit; import java.text.NumberFormat; import java.text.ParseException; import javax.swing.text.DefaultFormatterFactory; import javax.swing.text.NumberFormatter; /** * Implements a cell editor that uses a formatted text field * to edit Integer values. */ public class IntegerEditor extends DefaultCellEditor { JFormattedTextField ftf; NumberFormat integerFormat; private Integer minimum, maximum; private boolean DEBUG = false; public IntegerEditor(int min, int max) { super(new JFormattedTextField()); ftf = (JFormattedTextField)getComponent(); minimum = new Integer(min); maximum = new Integer(max); //Set up the editor for the integer cells. integerFormat = NumberFormat.getIntegerInstance(); NumberFormatter intFormatter = new NumberFormatter(integerFormat); intFormatter.setFormat(integerFormat); intFormatter.setMinimum(minimum); intFormatter.setMaximum(maximum); ftf.setFormatterFactory( new DefaultFormatterFactory(intFormatter)); ftf.setValue(minimum); ftf.setHorizontalAlignment(JTextField.TRAILING); ftf.setFocusLostBehavior(JFormattedTextField.PERSIST); //React when the user presses Enter while the editor is //active. (Tab is handled as specified by //JFormattedTextField's focusLostBehavior property.) ftf.getInputMap().put(KeyStroke.getKeyStroke( KeyEvent.VK_ENTER, 0), "check"); ftf.getActionMap().put("check", new AbstractAction() { public void actionPerformed(ActionEvent e) { if (!ftf.isEditValid()) { //The text is invalid. if (userSaysRevert()) { //reverted ftf.postActionEvent(); //inform the editor } } else try { //The text is valid, ftf.commitEdit(); //so use it. ftf.postActionEvent(); //stop editing } catch (java.text.ParseException exc) { } } }); } //Override to invoke setValue on the formatted text field. public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected, int row, int column) { JFormattedTextField ftf = (JFormattedTextField)super.getTableCellEditorComponent( table, value, isSelected, row, column); ftf.setValue(value); return ftf; } //Override to ensure that the value remains an Integer. public Object getCellEditorValue() { JFormattedTextField ftf = (JFormattedTextField)getComponent(); Object o = ftf.getValue(); if (o instanceof Integer) { return o; } else if (o instanceof Number) { return new Integer(((Number)o).intValue()); } else { if (DEBUG) { System.out.println("getCellEditorValue: o isn't a Number"); } try { return integerFormat.parseObject(o.toString()); } catch (ParseException exc) { System.err.println("getCellEditorValue: can't parse o: " + o); return null; } } } //Override to check whether the edit is valid, //setting the value if it is and complaining if //it isn't. If it's OK for the editor to go //away, we need to invoke the superclass's version //of this method so that everything gets cleaned up. public boolean stopCellEditing() { JFormattedTextField ftf = (JFormattedTextField)getComponent(); if (ftf.isEditValid()) { try { ftf.commitEdit(); } catch (java.text.ParseException exc) { } } else { //text is invalid if (!userSaysRevert()) { //user wants to edit return false; //don't let the editor go away } } return super.stopCellEditing(); } /** * Lets the user know that the text they entered is * bad. Returns true if the user elects to revert to * the last good value. Otherwise, returns false, * indicating that the user wants to continue editing. */ protected boolean userSaysRevert() { Toolkit.getDefaultToolkit().beep(); ftf.selectAll(); Object[] options = {"Edit", "Revert"}; int answer = JOptionPane.showOptionDialog( SwingUtilities.getWindowAncestor(ftf), "The value must be an integer between " + minimum + " and " + maximum + ".\n" + "You can either continue editing " + "or revert to the last valid value.", "Invalid Text Entered", JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE, null, options, options[1]);<code>
if (answer == 1) { //Revert!
ftf.setValue(ftf.getValue());
return true;
}
return false;
}
}
</code>
et l'appel ca se fait comme ca
table.setDefaultEditor(Integer.class, new edit_integer(1, 10000));
Je pense que ceci devrait aller (je n'ai pas testé, j'ai la flemme de créer un main complet)
J'ai cependant un doute sur l'adaptation de cette ligne :
J'ai cependant un doute sur l'adaptation de cette ligne :
integerFormat = NumberFormat.getIntegerInstance();En effet, NumberFormat n'a pas de méthode getDoubleInstance() je l'ai donc remplacé, mais sans certitude, par getNumberInstance()
import javax.swing.AbstractAction; import javax.swing.DefaultCellEditor; import javax.swing.JFormattedTextField; import javax.swing.JOptionPane; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.KeyStroke; import javax.swing.SwingUtilities; import java.awt.event.ActionEvent; import java.awt.event.KeyEvent; import java.awt.Component; import java.awt.Toolkit; import java.text.NumberFormat; import java.text.ParseException; import javax.swing.text.DefaultFormatterFactory; import javax.swing.text.NumberFormatter; /** * Implements a cell editor that uses a formatted text field * to edit Integer values. */ public class DoubleEditor extends DefaultCellEditor { private static final long serialVersionUID = 1; JFormattedTextField ftf; NumberFormat doubleFormat; private Double minimum, maximum; private boolean DEBUG = false; public DoubleEditor(double min, double max) { super(new JFormattedTextField()); ftf = (JFormattedTextField)getComponent(); minimum = min; maximum = max; //Set up the editor for the double cells. doubleFormat = NumberFormat.getNumberInstance(); //TODO NumberFormatter doubleFormatter = new NumberFormatter(doubleFormat); doubleFormatter.setFormat(doubleFormat); doubleFormatter.setMinimum(minimum); doubleFormatter.setMaximum(maximum); ftf.setFormatterFactory( new DefaultFormatterFactory(doubleFormatter)); ftf.setValue(minimum); ftf.setHorizontalAlignment(JTextField.TRAILING); ftf.setFocusLostBehavior(JFormattedTextField.PERSIST); //React when the user presses Enter while the editor is //active. (Tab is handled as specified by //JFormattedTextField's focusLostBehavior property.) ftf.getInputMap().put(KeyStroke.getKeyStroke( KeyEvent.VK_ENTER, 0), "check"); ftf.getActionMap().put("check", new AbstractAction() { private static final long serialVersionUID = 1; public void actionPerformed(ActionEvent e) { if (!ftf.isEditValid()) { //The text is invalid. if (userSaysRevert()) { //reverted ftf.postActionEvent(); //inform the editor } } else try { //The text is valid, ftf.commitEdit(); //so use it. ftf.postActionEvent(); //stop editing } catch (ParseException exc) { } } }); } //Override to invoke setValue on the formatted text field. public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected, int row, int column) { JFormattedTextField ftf = (JFormattedTextField)super.getTableCellEditorComponent( table, value, isSelected, row, column); ftf.setValue(value); return ftf; } //Override to ensure that the value remains a Double. public Object getCellEditorValue() { JFormattedTextField ftf = (JFormattedTextField)getComponent(); Object o = ftf.getValue(); if (o instanceof Double) { return o; } else if (o instanceof Number) { return new Double(((Number)o).doubleValue()); } else { if (DEBUG) { System.out.println("getCellEditorValue: o isn't a Double"); } try { return doubleFormat.parseObject(o.toString()); } catch (ParseException exc) { System.err.println("getCellEditorValue: can't parse o: " + o); return null; } } } //Override to check whether the edit is valid, //setting the value if it is and complaining if //it isn't. If it's OK for the editor to go //away, we need to invoke the superclass's version //of this method so that everything gets cleaned up. public boolean stopCellEditing() { JFormattedTextField ftf = (JFormattedTextField)getComponent(); if (ftf.isEditValid()) { try { ftf.commitEdit(); } catch (ParseException exc) { } } else { //text is invalid if (!userSaysRevert()) { //user wants to edit return false; //don't let the editor go away } } return super.stopCellEditing(); } /** * Lets the user know that the text they entered is * bad. Returns true if the user elects to revert to * the last good value. Otherwise, returns false, * indicating that the user wants to continue editing. */ protected boolean userSaysRevert() { Toolkit.getDefaultToolkit().beep(); ftf.selectAll(); Object[] options = {"Edit", "Revert"}; int answer = JOptionPane.showOptionDialog( SwingUtilities.getWindowAncestor(ftf), "The value must be an integer between " + minimum + " and " + maximum + ".\n" + "You can either continue editing " + "or revert to the last valid value.", "Invalid Text Entered", JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE, null, options, options[1]); if (answer == 1) { //Revert! ftf.setValue(ftf.getValue()); return true; } return false; } }
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
merci KX
tu m'a fait un grand plaisir
ca marché
sauf que moi j'ai l'habitude d'entrer les doubles comme 34.66 avec le point
mais dans ce ca si j' l entre la table va automatiquement prendre 34
elle n'accepte que les doubles comme 34,66 avec la virgule
tu m'a fait un grand plaisir
ca marché
sauf que moi j'ai l'habitude d'entrer les doubles comme 34.66 avec le point
mais dans ce ca si j' l entre la table va automatiquement prendre 34
elle n'accepte que les doubles comme 34,66 avec la virgule
C'est parce que ton ordinateur doit être configuré français, et que le point c'est plutôt anglais.
Sur la ligne où j'ai eu une hésitation (eh oui, ça vient de là !) tu peux essayer ceci :
C'est d'ailleurs surement pour ça que getDoubleInstance n'existe pas, parce que l'écriture des double dépend des langues !
Sur la ligne où j'ai eu une hésitation (eh oui, ça vient de là !) tu peux essayer ceci :
doubleFormat = NumberFormat.getNumberInstance(Locale.US)
C'est d'ailleurs surement pour ça que getDoubleInstance n'existe pas, parce que l'écriture des double dépend des langues !