首页 > Java > java教程 > 正文

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

DDD
发布: 2025-10-25 13:59:00
原创
186人浏览过

java swing:jtable数据求和并显示在jtextfield中

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

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

实现步骤

  1. 数据获取与循环遍历

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

   public void jTableMain() {
       MyQuery1 mq1 = new MyQuery1();
       ArrayList<Carrier1> 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 变量中。

立即学习Java免费学习笔记(深入)”;

  1. 将总和显示在JTextField中

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

芦笋演示
芦笋演示

一键出成片的录屏演示软件,专为制作产品演示、教学课程和使用教程而设计。

芦笋演示34
查看详情 芦笋演示
   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<Carrier1> 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<Carrier1> BookTable1() {
        // 模拟从数据库获取数据
        ArrayList<Carrier1> 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应用中进行数据统计和展示的基本方法,并能够将其应用到实际项目中。希望本教程对您有所帮助!

以上就是Java Swing:JTable数据求和并显示在JTextField中的详细内容,更多请关注php中文网其它相关文章!

Windows激活工具
Windows激活工具

Windows激活工具是正版认证的激活工具,永久激活,一键解决windows许可证即将过期。可激活win7系统、win8.1系统、win10系统、win11系统。下载后先看完视频激活教程,再进行操作,100%激活成功。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号