【转】java JTable排序和过滤
JTable排序
在Java SE 6中除了java.awt被更新外,javax.swing同时也有了很大的改进。在C/S程序中我们会经常使 用到"表"。如我们可以在查询数据库后将查询结果显示在表格中。在Java中显示表格使用的是JTable类。在以前的版本中,JTable只能简单地显 示数据,并没有什么附加的处理功能,而在Java SE 6中的JTable增加了排序和过滤功能。用户可以单击列头进行排序,也可以根据某一列来过滤表 中的数据。
为了使JTable可以对数据进行,必须将RowSorter类和JTable进行关联。RowSorter是一个抽象类,它负责将JTable中的 数据映射成可排序的数据。在真正使用时,我们将直接使用RowSorter的子类TableRowSorter。下面的代码显示了如何将TableRowSorter类和JTable相关联。
- TableModel model = new DefaultTableModel(rows, columns);
- JTable table = new JTable(model);
- RowSorter sorter = new TableRowSorter(model);
- table.setRowSorter(sorter);
上面代码首先建立一个TableModel,然后将这个TableModel的实例同时传递给了JTable和RowSorter。下面是一个使用JTable排序的简单的例子。
- import javax.swing.*;
- import javax.swing.table.*;
- import java.awt.*;
- public class TestSortedTable {
- public static void main(String args[]) {
- JFrame frame = new JFrame("JTable的排序测试");
- frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
- // 表格中显示的数据
- Object rows[][] = { { "王明", "中国", 44 }, { "姚明", "中国", 25 },
- { "赵子龙", "西蜀", 1234 }, { "曹操", "北魏", 2112 },
- { "Bill Gates", "美国", 45 }, { "Mike", "英国", 33 } };
- String columns[] = { "姓名", "国籍", "年龄" };
- TableModel model = new DefaultTableModel(rows, columns);
- JTable table = new JTable(model);
- RowSorter<TableModel> sorter = new TableRowSorter<TableModel>(model);
- table.setRowSorter(sorter);
- JScrollPane pane = new JScrollPane(table);
- frame.add(pane, BorderLayout.CENTER);
- frame.setSize(300, 150);
- frame.setVisible(true);
- }
- }

图3显示的是按"年龄"进行降序排列。但我们发现一个奇怪的问题,就是"年龄"字段并不是按数值类型进行排序的,而是按字符类型进行排序的。

出现这种情况是因为在默认情况下DefaultTableModal的列是Object类型。而要想使JTable按数值进行排序,必须要覆盖DefaultTableModal的getColumnClass方法。
- TableModel model = new DefaultTableModel(rows, columns) {
- public Class getColumnClass(int column) {
- Class returnValue;
- if ((column >= 0) && (column < getColumnCount())) {
- returnValue = getValueAt(0, column).getClass();
- } else {
- returnValue = Object.class;
- }
- return returnValue;
- }
- };

JTable过滤
在JTable中通过抽象类RowFilter类对行进行过滤。和排序不同,你可以不建立它们的子类,而使用这个抽象类的6个静态方法。
·andFilter
·dateFilter(RowFilter.ComparisonType type, Date date, int... indices)
·notFilter(RowFilter<M,I> filter)
·numberFilter(RowFilter.ComparisonType type, Number number, int... indices)
·orFilter
·regexFilter(String regex, int... indices)
其中andFilter()、orFilter()以及notFilter()方法的功能是将当前的过滤条件和其它的过滤条件进行组合。如在同时比较日期和数值时需要将日期过滤和数值过滤进行组合。这些组合是非常简单的。
RowFilter的类型比较允许你进行4种关系的比较,等于、不等于、大于或小于。我们可以通过指定某一列进行过滤,也可以对所有的列进行过滤。这 其中最为有趣的也许是正则表达式过滤(regular expression filter,或简称为regex filter)。使用这个过滤器可以对 表中数据进行更高级的过滤。下面是实现一个简单过滤器的代码。
- import javax.swing.*;
- import javax.swing.table.*;
- import java.awt.*;
- import java.awt.event.*;
- public class TestFilter {
- public static void main(String args[]) {
- JFrame frame = new JFrame("JTable的过滤测试");
- frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
- Object rows[][] = { { "王明", "中国", 44 }, { "姚明", "中国", 25 },
- { "赵子龙", "西蜀", 1234 }, { "曹操", "北魏", 2112 },
- { "Bill Gates", "美国", 45 }, { "Mike", "英国", 33 } };
- String columns[] = { "姓名", "国籍", "年龄" };
- TableModel model = new DefaultTableModel(rows, columns) {
- public Class getColumnClass(int column) {
- Class returnValue;
- if ((column >= 0) && (column < getColumnCount())) {
- returnValue = getValueAt(0, column).getClass();
- } else {
- returnValue = Object.class;
- }
- return returnValue;
- }
- };
- final JTable table = new JTable(model);
- final TableRowSorter<TableModel> sorter = new TableRowSorter<TableModel>(
- model);
- table.setRowSorter(sorter);
- JScrollPane pane = new JScrollPane(table);
- frame.add(pane, BorderLayout.CENTER);
- JPanel panel = new JPanel(new BorderLayout());
- JLabel label = new JLabel("过滤");
- panel.add(label, BorderLayout.WEST);
- final JTextField filterText = new JTextField("");
- panel.add(filterText, BorderLayout.CENTER);
- frame.add(panel, BorderLayout.NORTH);
- JButton button = new JButton("过滤");
- button.addActionListener(new ActionListener() {
- public void actionPerformed(ActionEvent e) {
- String text = filterText.getText();
- if (text.length() == 0) {
- sorter.setRowFilter(null);
- } else {
- sorter.setRowFilter(RowFilter.regexFilter(text));
- }
- }
- });
- frame.add(button, BorderLayout.SOUTH);
- frame.setSize(300, 250);
- frame.setVisible(true);
- }
- }
图5是上面程序的运行界面。

以下是销售系统中表格中实现过滤功能,过滤第5列即销售列(字段包括“已售”、“预订"、”未售“),
- if(displaySaleStatus==0&&displayBookStatus==0&&displayNotBookStatus==0)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("什么都不显示哦", 4));
- if(displaySaleStatus==1&&displayBookStatus==0&&displayNotBookStatus==0)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("已售", 4));
- else if(displaySaleStatus==0&&displayBookStatus==1&&displayNotBookStatus==0)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("预订", 4));
- else if(displaySaleStatus==0&&displayBookStatus==0&&displayNotBookStatus==1)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("未订", 4));
- else if(displaySaleStatus==1&&displayBookStatus==1&&displayNotBookStatus==0)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("已售|预订", 4));
- else if(displaySaleStatus==0&&displayBookStatus==1&&displayNotBookStatus==1)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("预订|未订", 4));
- else if(displaySaleStatus==1&&displayBookStatus==0&&displayNotBookStatus==1)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("已售|未订", 4));
- else if(displaySaleStatus==1&&displayBookStatus==1&&displayNotBookStatus==1)
- ((TableRowSorter)this.table.getRowSorter()).setRowFilter(RowFilter.regexFilter("已售|预订|未订", 4));//全部显示,或setRowFilter(null)
一下是地震发布系统中过滤第2列即震级列(字段为Float型)
- /**
- * (大、中、小地震)显示按钮事件处理过程
- * */
- @SuppressWarnings("unchecked")
- private void showActionHandle(){
- boolean showBigEqStatus=showBigEqBut.isSelected();
- boolean showMiddleEqStatus=showMiddleEqBut.isSelected();
- boolean showSmallEqStatus=showSmallEqBut.isSelected();
- if(showBigEqStatus==false&&showMiddleEqStatus==false&&showSmallEqStatus==false)
- ((TableRowSorter)this.getRowSorter()).setRowFilter(RowFilter.numberFilter(ComparisonType.AFTER, 100,2));
- if(showBigEqStatus==true&&showMiddleEqStatus==false&&showSmallEqStatus==false){
- ((TableRowSorter)this.getRowSorter()).setRowFilter(RowFilter.numberFilter(ComparisonType.AFTER,TableAttribute.BIG_EARTHQUAKE_THRESHOLD,2));
- }
- else if(showBigEqStatus==false&&showMiddleEqStatus==true&&showSmallEqStatus==false){
- List<RowFilter<Object,Object>> filters = new ArrayList<RowFilter<Object,Object>>(2);
- filters.add(RowFilter.numberFilter(ComparisonType.AFTER,TableAttribute.MIDDLE_EARTHQUAKE_THRESHOLD,2));
- filters.add(RowFilter.numberFilter(ComparisonType.BEFORE,TableAttribute.BIG_EARTHQUAKE_THRESHOLD,2));
- RowFilter<Object,Object> fooBarFilter = RowFilter.andFilter(filters);
- ((TableRowSorter)this.getRowSorter()).setRowFilter(fooBarFilter);
- }
- else if(showBigEqStatus==false&&showMiddleEqStatus==false&&showSmallEqStatus==true){
- ((TableRowSorter)this.getRowSorter()).setRowFilter(RowFilter.numberFilter(ComparisonType.BEFORE,TableAttribute.MIDDLE_EARTHQUAKE_THRESHOLD,2));
- }
- else if(showBigEqStatus==true&&showMiddleEqStatus==true&&showSmallEqStatus==false){
- ((TableRowSorter)this.getRowSorter()).setRowFilter(RowFilter.numberFilter(ComparisonType.AFTER,TableAttribute.MIDDLE_EARTHQUAKE_THRESHOLD,2));
- }
- else if(showBigEqStatus==false&&showMiddleEqStatus==true&&showSmallEqStatus==true){
- ((TableRowSorter)this.getRowSorter()).setRowFilter(RowFilter.numberFilter(ComparisonType.BEFORE,TableAttribute.BIG_EARTHQUAKE_THRESHOLD,2));
- }
- else if(showBigEqStatus==true&&showMiddleEqStatus==false&&showSmallEqStatus==true){
- List<RowFilter<Object,Object>> filters = new ArrayList<RowFilter<Object,Object>>(2);
- filters.add(RowFilter.numberFilter(ComparisonType.AFTER,TableAttribute.BIG_EARTHQUAKE_THRESHOLD,2));
- filters.add(RowFilter.numberFilter(ComparisonType.BEFORE,TableAttribute.MIDDLE_EARTHQUAKE_THRESHOLD,2));
- RowFilter<Object,Object> fooBarFilter = RowFilter.orFilter(filters);
- ((TableRowSorter)this.getRowSorter()).setRowFilter(fooBarFilter);
- }
- else if(showBigEqStatus==true&&showMiddleEqStatus==true&&showSmallEqStatus==true){
- ((TableRowSorter)this.getRowSorter()).setRowFilter(RowFilter.numberFilter(ComparisonType.AFTER, 0,2));
- }
- }
补充:将表格视图中的行号映射到模型中对应的行号,才能正确地得到行的内容,尤其是自动排序后,视图中的行号与表格模型中的行号不一致,TableModel中的方法getValueAt(row,column)中的row指模型中的row,而通过table.getSelectedRow()或者事件处理中通过table.rowAtPoint(e.getPoint())得到row指视图中的row,因此必须将视图中的row转化为model中的row:
int view_row = table.rowAtPoint(e.getPoint()); //获得视图中的行索引
int view_col = table.columnAtPoint(e.getPoint()); //获得视图中的列索引
int model_row= table.convertRowIndexToModel(row);//将视图中的行索引转化为数据模型中的行索引
int model_col = table.convertColumnIndexToModel(col);//将视图中的列索引转化为数据模型中的列索引
本文转自:http://blog.csdn.net/b_h_l/article/details/7771944
【转】java JTable排序和过滤的更多相关文章
- [Android分享] 【转帖】Android ListView的A-Z字母排序和过滤搜索功能
感谢eoe社区的分享 最近看关于Android实现ListView的功能问题,一直都是小伙伴们关心探讨的Android开发问题之一,今天看到有关ListView实现A-Z字母排序和过滤搜索功能 ...
- Android 实现ListView的A-Z字母排序和过滤搜索功能,实现汉字转成拼音
转载:http://blog.csdn.net/xiaanming/article/details/12684155 转载请注明出处:http://blog.csdn.net/xiaanming/ar ...
- 【JUnit4.10源码分析】6.1 排序和过滤
abstract class ParentRunner<T> extends Runner implements Filterable,Sortable 本节介绍排序和过滤. (尽管JUn ...
- 手把手教你如何用java8新特性将List中按指定属性排序,过滤重复数据
在java中常常会遇到这样一个问题,在实际应用中,总会碰到对List排序并过滤重复的问题,如果List中放的只是简单的String类型过滤so easy,但是实际应用中并不会这么easy,往往List ...
- Java实现敏感词过滤
敏感词.文字过滤是一个网站必不可少的功能,如何设计一个好的.高效的过滤算法是非常有必要的.前段时间我一个朋友(马上毕业,接触编程不久)要我帮他看一个文字过滤的东西,它说检索效率非常慢.我把它程序拿过来 ...
- Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法
Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...
- 让Asp.Net WebAPI支持OData查询,排序,过滤。
让Asp.Net WebAPI支持OData后,就能支持在url中直接输入排序,过滤条件了. 一.创建Asp.Net WebAPI项目: 二.使用NuGet安装Asp.Net WebAPI 2.2和O ...
- Java 常用排序算法/程序员必须掌握的 8大排序算法
Java 常用排序算法/程序员必须掌握的 8大排序算法 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配 ...
- Contoso 大学 - 3 - 排序、过滤及分页
原文 Contoso 大学 - 3 - 排序.过滤及分页 目录 Contoso 大学 - 使用 EF Code First 创建 MVC 应用 原文地址:http://www.asp.net/mvc/ ...
随机推荐
- Hasor:生命周期
首先引用Wiki的介绍一下Hasor: “Hasor是一款开源框架.它是为了解决企业模块化开发中复杂性而创建的.Hasor遵循简单的依赖.单一职责,在开发多模块企业项目中更加有调理.然而Has ...
- android 防止多次点击,它会导致事件侦听响应于其他接口
这里有情况: A当点击跳转至B介面,点击B接口结束后,到A界面中 1.此时在B界面中,设置点击事件,点击后结束B v.setOnClickListener(new OnClickListener() ...
- ural1018(树形dp)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=17662 题意:给一棵边有权值的二叉树,节点编号为1-n,1是根节点 ...
- 在Java中如何使用jdbc连接Sql2008数据库(转)
我们在javaEE的开发中,肯定是要用到数据库的,那么在javaEE的开发中,是如何使用代码实现和SQL2008的连接的呢?在这一篇文章中,我将讲解如何最简单的使用jdbc进行SQL2008的数据库的 ...
- 数据库采用多表连接查询,对应javaBean文件连接方式
在一个Web项目中,只要是存在数据库就一定会有JavaBean文件.一个JavaBean文件会对应一张数据库中的表,供dao中的代码来调用用来存取数据.我们都知道,在数据库设计的时候,如果A.B两张表 ...
- ecshop 全目录说明
ECShop 2.5.1 的结构图及各文件相应功能介绍 ECShop2.5.1_Beta upload 的目录 ┣ activity.php 活动列表 ...
- centos 6.5 升级内核 linux 3.12.17
环境: 系统硬件:vmware vsphere (CPU:2*4核,内存2G) 系统版本:Linux centos 2.6.32-431.el6.x86_64(Centos-6.5-x86_64-mi ...
- Android 从硬件到应用程序:一步一步爬上去 5 -- 在Frameworks蒂姆层硬件服务
Android Frameworks层提供硬件服务,Android系统APP能够调用这些硬件服务,而硬件则完全控制.实现应有的功能.上一页下一页.为了这一个frameworks高层的应用java接口硬 ...
- hbase列表排序
hbase都是依照字典序进行排序的,也就是降序,在页面的表现就是最早的数据(rowkey最小的)排在前面. 眼下的解决方式是:给主键添加一个外键关联表.外键的生成规则是 400000000000-主键 ...
- Ubuntu Linux 永山(mount)分
在一般情况下,我们想安装一个分区解决方案是使用mount命令,因为我想/dev/sda3安装/media/aborn/data通过使用下面的命令 sudo mount /dev/sda3 /media ...