在 Java 中创建表格
 
在本文中,我们将研究 Java 中的表格。
我们将在以下部分讨论两种使用表格的方法。基本表具有行和列,以可读结构显示数据。
在 Java 中使用 JTable 创建表格
在本例中,我们使用 Java 中 GUI 库 Swing 的 JTable 组件。我们创建一个 JFrame 对象来在窗口中显示表格;然后,我们创建一个包含原始数据的二维数组 tableData。
我们创建一个包含字段名称的数组来显示列字段。现在我们创建一个 JTable 的对象,并将 tableData 和 tableColumn 作为参数传递给构造函数。
我们使用 setBounds() 方法设置 JTable 的大小。当表格数据增长超过大小时,为了使表格可滚动,我们使用 JScrollPane,当组件超出视图时显示滚动条。
最后,我们将 JScrollPane 对象添加到 JFrame 并设置框架的大小和可见性。
import javax.swing.*;
public class JavaExample {
  public static void main(String[] args) {
    JFrame jFrame = new JFrame();
    String[][] tableData = {{"01", "Adam", "1986"}, {"02", "John", "1990"}, {"03", "Sam", "1989"},
        {"04", "Derek", "1991"}, {"05", "Ben", "1981"}};
    String[] tableColumn = {"ID", "FIRST NAME", "BIRTH YEAR"};
    JTable jTable = new JTable(tableData, tableColumn);
    jTable.setBounds(30, 40, 230, 280);
    JScrollPane jScrollPane = new JScrollPane(jTable);
    jFrame.add(jScrollPane);
    jFrame.setSize(350, 300);
    jFrame.setVisible(true);
  }
}
输出:

在 Java 中使用 Guava 库创建表格
我们还可以使用 com.google.common.collect 包的 Table 接口,它是 Guava 库的一部分。在程序中,我们创建了一个 HashBasedTable 类的实例,它通过调用 create() 实现 Table 接口并返回一个 Table 类型的对象。
Table 有三个类型参数:第一个是行键的类型,第二个是列键的类型,最后一个参数是映射到键的值的类型。行和列的键与单个值相关联。
我们使用 Table 对象调用 put() 方法。在 put() 函数中,我们传递三个参数:行的键,列的键,最后一个是要映射的值。
我们可以使用 Table 接口及其类执行多个操作。row() 和 column() 是获取与行或列键对应的值和键的两种方法。
当我们调用 table.row() 并传递行键时,我们得到一个映射作为回报。我们使用这个 getRows 映射来调用返回元素 Set 的 entrySet()。
现在我们使用 Set 来获取 Map.Entry 的 stringEntry,它提供了一个地图条目。我们使用 getKey 和 getValue 方法获取键和值。
我们按照相同的步骤使用 column() 方法获取行键和值。rowMap() 和 columnMap() 等方法返回整个表数据。
rowKeySet() 返回表中的所有行键。
import com.google.common.collect.HashBasedTable;
import com.google.common.collect.Table;
import java.util.Map;
public class JavaExample {
  public static void main(String[] args) {
    Table<String, String, String> table = HashBasedTable.create();
    table.put("Adam", "1990", "101");
    table.put("John", "1994", "102");
    table.put("Jane", "1991", "103");
    table.put("John", "1995", "104");
    table.put("Adam", "1996", "105");
    table.put("Sam", "1991", "106");
    table.put("Watson", "1994", "107");
    table.put("Kelly", "1994", "108");
    table.put("Martha", "1995", "109");
    table.put("Billy", "1994", "107");
    Map<String, String> getRows = table.row("Adam");
    System.out.println("Row Results: ");
    for (Map.Entry<String, String> stringEntry : getRows.entrySet()) {
      System.out.println(
          "Birth Year: " + stringEntry.getKey() + " | ID: " + stringEntry.getValue());
    }
    System.out.println();
    Map<String, String> getCols = table.column("1994");
    System.out.println("Column Results: ");
    for (Map.Entry<String, String> stringEntry : getCols.entrySet()) {
      System.out.println(
          "First Name: " + stringEntry.getKey() + " | ID: " + stringEntry.getValue());
    }
    System.out.println();
    System.out.println("Row Map Data Of Table: " + table.rowMap());
    System.out.println();
    System.out.println("All The Keys: " + table.rowKeySet());
  }
}
输出:
Row Results:
Birth Year: 1990 | ID: 101
Birth Year: 1996 | ID: 105
Column Results:
First Name: Billy | ID: 107
First Name: John | ID: 102
First Name: Watson | ID: 107
First Name: Kelly | ID: 108
Row Map Data Of Table: {Adam={1990=101, 1996=105}, Billy={1994=107}, John={1994=102, 1995=104}, Watson={1994=107}, Jane={1991=103}, Sam={1991=106}, Martha={1995=109}, Kelly={1994=108}}
All The Keys: [Adam, Billy, John, Watson, Jane, Sam, Martha, Kelly]
Rupam Saini is an android developer, who also works sometimes as a web developer., He likes to read books and write about various things.
LinkedIn