Java Swing:JTable数据求和并显示在JTextField中

本文档旨在指导开发者如何在使用Java Swing构建的图书管理项目中,从JTable中获取价格数据,计算总和,并将结果显示在JTextField组件中。我们将详细讲解代码实现,并提供注意事项,确保读者能够顺利完成功能开发。

在Java Swing应用中,经常需要对表格(JTable)中的数据进行统计计算,并将结果展示在界面上。本教程将以一个图书管理系统为例,讲解如何从JTable中读取价格数据,计算总和,并将结果显示在JTextField中。

实现步骤

  1. 数据获取与循环遍历

首先,需要获取JTable的数据源,通常是一个ArrayList或其他集合类。然后,使用循环遍历集合中的每个元素,提取出价格信息。

   public void jTableMain() {
       MyQuery1 mq1 = new MyQuery1();
       ArrayList list = mq1.BookTable1();
       String[] columnName = {"책 코드", "책 이름", "로 고", "가 격"};
       Object[][] rows = new Object[list.size()][4];
       int sum = 0;

       for(int i = 0; i < list.size(); i++) {
           Carrier1 carrier = list.get(i); // 获取当前书籍对象
           rows[i][0] = carrier.getBook_code();
           rows[i][1] = carrier.getBook_name();

           if(carrier.getBookImage() != null) {
               ImageIcon image = new ImageIcon(new ImageIcon(carrier.getBookImage()).getImage().getScaledInstance(100, 90, Image.SCALE_SMOOTH));
               rows[i][2] = image;
           } else {
               rows[i][2] = null;
           }

           int price = carrier.getPrice(); // 获取书籍价格
           sum += price; // 累加价格
           rows[i][3] = price;
       }

       TheModel model = new TheModel (rows, columnName);

       jTableMain.setModel(model); // 数据加载到JTable
       jTableMain.setRowHeight(90); // 设置JTable行高
       jTableMain.getColumnModel().getColumn(2).setPreferredWidth(100);

       jTableSubMain.setModel(model); // 数据加载到另一个JTable
   }

在上述代码中,list 是包含书籍信息的 ArrayList,Carrier1 是表示书籍信息的类,包含 getPrice() 方法用于获取书籍价格。在循环中,我们首先获取当前书籍对象,然后提取其价格,并将其累加到 sum 变量中。

  1. 将总和显示在JTextField中

在计算出总和后,需要将其显示在JTextField中。首先,确保你已经创建了一个JTextField对象,并将其添加到你的Swing界面中。

   JTextField totalPriceTextField = new JTextField();
   // 将totalPriceTextField添加到你的JFrame或JPanel中

然后,在 jTableMain() 方法的末尾,将计算出的总和转换为字符串,并设置JTextField的文本。

   // ... 上面的代码 ...

   // 将总和显示在JTextField中
   totalPriceTextField.setText(String.valueOf(sum));

String.valueOf(sum) 将整数类型的 sum 转换为字符串类型,totalPriceTextField.setText() 方法用于设置JTextField的文本。

完整示例代码

下面是完整的示例代码,包含了数据获取、循环遍历、计算总和以及将结果显示在JTextField中:

import javax.swing.*;
import java.awt.*;
import java.util.ArrayList;

public class BookManagement {

    private JTable jTableMain;
    private JTable jTableSubMain;
    private JTextField totalPriceTextField;

    public BookManagement() {
   

// 初始化界面组件,包括JTable和JTextField jTableMain = new JTable(); jTableSubMain = new JTable(); totalPriceTextField = new JTextField(); // 假设界面布局已经完成,并将jTableMain、jTableSubMain和totalPriceTextField添加到界面中 } public void jTableMain() { MyQuery1 mq1 = new MyQuery1(); ArrayList list = mq1.BookTable1(); String[] columnName = {"책 코드", "책 이름", "로 고", "가 격"}; Object[][] rows = new Object[list.size()][4]; int sum = 0; for(int i = 0; i < list.size(); i++) { Carrier1 carrier = list.get(i); rows[i][0] = carrier.getBook_code(); rows[i][1] = carrier.getBook_name(); if(carrier.getBookImage() != null) { ImageIcon image = new ImageIcon(new ImageIcon(carrier.getBookImage()).getImage().getScaledInstance(100, 90, Image.SCALE_SMOOTH)); rows[i][2] = image; } else { rows[i][2] = null; } int price = carrier.getPrice(); sum += price; rows[i][3] = price; } TheModel model = new TheModel (rows, columnName); jTableMain.setModel(model); jTableMain.setRowHeight(90); jTableMain.getColumnModel().getColumn(2).setPreferredWidth(100); jTableSubMain.setModel(model); // 将总和显示在JTextField中 totalPriceTextField.setText(String.valueOf(sum)); } public static void main(String[] args) { SwingUtilities.invokeLater(() -> { BookManagement bookManagement = new BookManagement(); bookManagement.jTableMain(); // 加载数据并计算总价 JFrame frame = new JFrame("Book Management"); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 为了演示,这里简单地添加组件,实际项目中需要更复杂的布局 JPanel panel = new JPanel(new BorderLayout()); panel.add(new JScrollPane(bookManagement.jTableMain), BorderLayout.CENTER); JPanel southPanel = new JPanel(); southPanel.add(new JLabel("Total Price:")); southPanel.add(bookManagement.totalPriceTextField); panel.add(southPanel, BorderLayout.SOUTH); frame.add(panel); frame.setSize(600, 400); frame.setVisible(true); }); } } // 假设的Carrier1类和MyQuery1类,需要根据实际项目进行调整 class Carrier1 { private String book_code; private String book_name; private byte[] bookImage; private int price; public Carrier1(String book_code, String book_name, byte[] bookImage, int price) { this.book_code = book_code; this.book_name = book_name; this.bookImage = bookImage; this.price = price; } public String getBook_code() { return book_code; } public String getBook_name() { return book_name; } public byte[] getBookImage() { return bookImage; } public int getPrice() { return price; } } class MyQuery1 { public ArrayList BookTable1() { // 模拟从数据库获取数据 ArrayList list = new ArrayList<>(); list.add(new Carrier1("1", "Book A", null, 10)); list.add(new Carrier1("2", "Book B", null, 20)); list.add(new Carrier1("3", "Book C", null, 30)); return list; } } class TheModel extends AbstractTableModel { private Object[][] data; private String[] columnNames; public TheModel(Object[][] data, String[] columnNames) { this.data = data; this.columnNames = columnNames; } @Override public int getRowCount() { return data.length; } @Override public int getColumnCount() { return columnNames.length; } @Override public Object getValueAt(int rowIndex, int columnIndex) { return data[rowIndex][columnIndex]; } @Override public String getColumnName(int column) { return columnNames[column]; } }

注意事项

  • 数据类型转换: 确保从JTable中获取的价格数据类型与累加变量 sum 的数据类型一致。如果JTable中的价格是字符串类型,需要先将其转换为整数类型,例如使用 Integer.parseInt() 方法。
  • 异常处理: 在将字符串转换为整数时,可能会出现 NumberFormatException 异常,需要进行适当的异常处理。
  • 界面更新: 如果JTable的数据是动态变化的,需要在数据更新后重新计算总和并更新JTextField的文本。可以使用事件监听器监听JTable的数据变化,并在事件处理方法中执行上述操作。
  • 线程安全: 如果数据获取和计算总和的操作在后台线程中进行,需要确保JTextField的更新操作在Swing事件派发线程中执行,以避免线程安全问题。可以使用 SwingUtilities.invokeLater() 方法将更新操作提交到Swing事件派发线程中。

总结

本教程详细讲解了如何从Java Swing的JTable中获取价格数据,计算总和,并将结果显示在JTextField中。通过本教程的学习,读者可以掌握在Swing应用中进行数据统计和展示的基本方法,并能够将其应用到实际项目中。希望本教程对您有所帮助!