1. por favor tengo un problema con la RowFilter (su ComparisonType) para armar

    • Regex(String), Número, Fecha

    junto con

    • Y, O, NI
  2. ni idea de cómo

    • para manejar con valor nulo Y, O, NI
    • si Regex(String), Número, Fecha tiene la misma lógica o no «pequeñas diferencias»
    • especialmente cómo comparar el valor de Fecha
  3. algunas más largas y detalladas descripciones son bienvenidos

  4. en este SSCCE a ver a mis problemas básicos en frame.add(new JButton(new AbstractAction("Toggle filter") {

JTable, RowFilter y RowFilter.La entrada

import java.awt.BorderLayout;
import java.awt.event.ActionEvent;
import java.util.Calendar;
import java.util.Date;
import javax.swing.*;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableModel;
import javax.swing.table.TableRowSorter;
public class JTableFilterDemo {
private static TableRowSorter<TableModel> sorter;
private Object[][] data = {{"A", 5, true, new Date()},
{"B", 2, false, new Date()}, {"C", 4, false, new Date()},
{"D", 8, true, new Date()}, {"E", 13, false, new Date()},
{"F", 7, true, new Date()}, {"G", 55, false, new Date()},
{"H", 6, false, new Date()}, {"I", 1, true, new Date()}};
private String columnNames[] = {"Item", "Value", "Boolean", "Date"};
private TableModel model = new DefaultTableModel(data, columnNames) {
private static final long serialVersionUID = 1L;
@Override
public Class<?> getColumnClass(int column) {
switch (column) {
case 1:
return Integer.class;
case 2:
return Boolean.class;
case 3:
return Date.class;
default:
return String.class;
}
}
};
private JTable table = new JTable(model);
private Date modifDate = new Date();
public JTableFilterDemo() {
modifyDateInTable();
table.setPreferredScrollableViewportSize(table.getPreferredSize());
RowFilter<Object, Number> filter = new RowFilter<Object, Number>() {
@Override
public boolean include(RowFilter.Entry entry) {
//String str = (String) entry.getValue(0);//String
//return str.matches(("(?i)^a|^g"));//String
//Boolean bol = (Boolean) entry.getValue(2);//Boolean
//return bol.booleanValue() == false;//Boolean
//Date date = (Date) entry.getValue(3);//Date
//return date.getTime() > (long) (new Date().getTime());//Date
//return ((Number) entry.getValue(1)).intValue() % 2 == 0;//Integer
//return ((Number) entry.getValue(1)).intValue() > 0;//Integer
return ((Number) entry.getValue(1)).intValue() > 10
& ((Number) entry.getValue(1)).intValue() < 50;//AND with Integer
}
};
sorter = new TableRowSorter<TableModel>(model);
sorter.setRowFilter(filter);
table.setRowSorter(sorter);
JScrollPane scrollPane = new JScrollPane(table);
JFrame frame = new JFrame("Filtering Table");
frame.add(new JButton(new AbstractAction("Toggle filter") {
private static final long serialVersionUID = 1L;
private RowFilter<TableModel, Object> filter = new RowFilter<TableModel, Object>() {
@Override
public boolean include(javax.swing.RowFilter.Entry<? extends TableModel, ? extends Object> entry) {
//String str = (String) entry.getValue(0);//String
//return str.matches(("(?i)^a|^g"));//String
//Boolean bol = (Boolean) entry.getValue(2);//Boolean
//return bol.booleanValue() == false;//Boolean
//Date date = (Date) entry.getValue(3);//Date
//return date.getTime() > (long) (new Date().getTime());//Date
//return ((Number) entry.getValue(1)).intValue() % 2 == 0;//Integer
//return ((Number) entry.getValue(1)).intValue() > 0;//Integer
return ((Number) entry.getValue(1)).intValue() > 10
& ((Number) entry.getValue(1)).intValue() < 50;//AND with Integer
//--->  doesn't works
//return ((Number) entry.getValue(1)).intValue() > 10 |
//((Number) entry.getValue(1)).intValue() < 50;//OR with Integer
//---> works, but initialized on 2nd. event
//return ((Number) entry.getValue(1)).intValue() > 10 != 
//((Number) entry.getValue(1)).intValue() < 50;//NOR with Integer 
}
};
@Override
public void actionPerformed(ActionEvent e) {
if (sorter.getRowFilter() != null) {
sorter.setRowFilter(null);
} else {
sorter.setRowFilter(filter);
}
}
}), BorderLayout.SOUTH);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(scrollPane);
frame.pack();
frame.setVisible(true);
}
private void modifyDateInTable() {
Calendar c = Calendar.getInstance();
c.setTime(modifDate);
c.add(Calendar.DATE, - 1);
modifDate = c.getTime();
table.setValueAt(modifDate, 0, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, +5);
modifDate = c.getTime();
table.setValueAt(modifDate, 1, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, +1);
modifDate = c.getTime();
table.setValueAt(modifDate, 2, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, - 16);
modifDate = c.getTime();
table.setValueAt(modifDate, 3, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, +30);
modifDate = c.getTime();
table.setValueAt(modifDate, 4, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, +55);
modifDate = c.getTime();
table.setValueAt(modifDate, 5, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, +155);
modifDate = c.getTime();
table.setValueAt(modifDate, 6, 3);
c.setTime(modifDate);
c.add(Calendar.DATE, -23);
modifDate = c.getTime();
table.setValueAt(modifDate, 7, 3);
}
public static void main(String[] args) {
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
JTableFilterDemo jtfd = new JTableFilterDemo();
}
});
}
}
  • Hace esto más simple relacionados con la ejemplo ofrecer alguna orientación?
  • gracias, tengo que pensar (tal vez seguro) que no, mi pregunta es acerca de EN/FUERA del rango definido por RowFilter.La ENTRADA
InformationsquelleAutor mKorbel | 2013-07-25

1 Comentario

  1. 7

    Veo ningún resultado inesperado.

    1. El primer predicado es sencilla; se incluye la intersección de la superposición de dos conjuntos, con la fila de haber Value 13 como único miembro.

      return ((Number) entry.getValue(1)).intValue() > 10
      & ((Number) entry.getValue(1)).intValue() < 50;
    2. El segundo predicado es la unión de la superposición de dos conjuntos, con todas las filas incluido.

      return ((Number) entry.getValue(1)).intValue() > 10 |
      ((Number) entry.getValue(1)).intValue() < 50;
    3. La tercera predicado es la complementar de la primera, con la fila de haber Value 13 alternativamente incluidos y excluidos.

      return ((Number) entry.getValue(1)).intValue() > 10 != 
      ((Number) entry.getValue(1)).intValue() < 50;

    Anexo: Relación RowFilter.Entry, me pareció útil para examinar cómo la y, o y no fábricas de usar el extra index parámetro definido en la clase privada RowFilter.GeneralFilter; cada subclase invoca el padre de la implementación de include() para cada filtro se suministra en el constructor. En contraste, la fecha, número y regex de las fábricas no; en lugar de eso, cada uno se basa en los predicados disponibles para el tipo subyacente.

    Addendum: Como un ejemplo concreto, seleccione el modelo de dos fechas, por ejemplo, la primera y la penúltima.

    Date d1 = (Date) model.getValueAt(0, 3);
    Date d2 = (Date) model.getValueAt(model.getRowCount() - 2, 3);

    Crear dos filtros que soporte las fechas elegidas.

    RowFilter<TableModel, Integer> low = 
    RowFilter.dateFilter(RowFilter.ComparisonType.AFTER, d1, 3);
    RowFilter<TableModel, Integer> high = 
    RowFilter.dateFilter(RowFilter.ComparisonType.BEFORE, d2, 3);

    Combinarlos en un andFilter.

    List<RowFilter<TableModel, Integer>> filters = Arrays.asList(low, high);
    final RowFilter<TableModel, Integer> filter = RowFilter.andFilter(filters);

    El resultado selecciona las filas entre, pero excluyendo, d1 y d2.

    Modificado SSCCE:

    import java.awt.BorderLayout;
    import java.awt.event.ActionEvent;
    import java.util.Arrays;
    import java.util.Calendar;
    import java.util.Date;
    import java.util.List;
    import javax.swing.*;
    import javax.swing.table.DefaultTableModel;
    import javax.swing.table.TableModel;
    import javax.swing.table.TableRowSorter;
    public class JTableFilterDemo {
    private static TableRowSorter<TableModel> sorter;
    private Object[][] data = {{"A", 5, true, new Date()},
    {"B", 2, false, new Date()}, {"C", 4, false, new Date()},
    {"D", 8, true, new Date()}, {"E", 13, false, new Date()},
    {"F", 7, true, new Date()}, {"G", 55, false, new Date()},
    {"H", 6, false, new Date()}, {"I", 1, true, new Date()}};
    private String columnNames[] = {"Item", "Value", "Boolean", "Date"};
    private TableModel model = new DefaultTableModel(data, columnNames) {
    @Override
    public Class<?> getColumnClass(int column) {
    switch (column) {
    case 1:
    return Integer.class;
    case 2:
    return Boolean.class;
    case 3:
    return Date.class;
    default:
    return String.class;
    }
    }
    };
    private JTable table = new JTable(model);
    public JTableFilterDemo() {
    modifyDateInTable();
    table.setPreferredScrollableViewportSize(table.getPreferredSize());
    sorter = new TableRowSorter<TableModel>(model);
    table.setRowSorter(sorter);
    Date d1 = (Date) model.getValueAt(0, 3);
    Date d2 = (Date) model.getValueAt(model.getRowCount() - 2, 3);
    RowFilter<TableModel, Integer> low = RowFilter.dateFilter(RowFilter.ComparisonType.AFTER, d1, 3);
    RowFilter<TableModel, Integer> high = RowFilter.dateFilter(RowFilter.ComparisonType.BEFORE, d2, 3);
    List<RowFilter<TableModel, Integer>> filters = Arrays.asList(low, high);
    final RowFilter<TableModel, Integer> filter = RowFilter.andFilter(filters);
    JScrollPane scrollPane = new JScrollPane(table);
    JFrame frame = new JFrame("Filtering Table");
    frame.add(new JButton(new AbstractAction("Toggle filter") {
    @Override
    public void actionPerformed(ActionEvent e) {
    if (sorter.getRowFilter() != null) {
    sorter.setRowFilter(null);
    } else {
    sorter.setRowFilter(filter);
    }
    }
    }), BorderLayout.SOUTH);
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    frame.add(scrollPane);
    frame.pack();
    frame.setLocationByPlatform(true);
    frame.setVisible(true);
    }
    private void modifyDateInTable() {
    Date modifDate = new Date();
    Calendar c = Calendar.getInstance();
    c.setTime(modifDate);
    c.add(Calendar.DATE, - 1);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 0, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, +5);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 1, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, +1);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 2, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, - 16);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 3, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, +30);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 4, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, +55);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 5, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, +155);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 6, 3);
    c.setTime(modifDate);
    c.add(Calendar.DATE, -23);
    modifDate = c.getTime();
    table.setValueAt(modifDate, 7, 3);
    }
    public static void main(String[] args) {
    SwingUtilities.invokeLater(new Runnable() {
    @Override
    public void run() {
    JTableFilterDemo jtfd = new JTableFilterDemo();
    }
    });
    }
    }
    • gracias por responder a mi carece, descripción, totalmente responder a mi punto 4º.
    • No estoy seguro de entender, pero he elaborado anteriormente.
    • 1. gracias acabo de entender (la edición) 2. Estoy buscando acerca de la combinación(s) de Fecha con Y (U, NI) RowFilter, poner juntos dos métodos (como la cláusula SQL, DONDE con un par de Y/O en la declaración), 3. mi código publicado aquí es sólo el mal, muy mal simulaciones de, 4. AFAIK aterai o Walter Laan comentó que estos puestos, y como usted sabe muy bien que esto es muy específico de la API sin respuestas, ms responden, (algunos comentarios sobre OTN kleopatra, pero sin código), Extra-Terrestre, un par de Ovnis en comparar con el CardLayout….
    • Ah, creo entender; he añadido un ejemplo.
    • gracias me pierdas esta lógicas para RowFilter.ComparisonType.XXX

Dejar respuesta

Please enter your comment!
Please enter your name here