当前位置:首页 > 文章列表 > 文章 > java教程 > JTable数据求和显示到文本框方法

JTable数据求和显示到文本框方法

2025-11-17 23:54:32 0浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《JTable数据求和显示在JTextField中方法》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下,希望所有认真读完的童鞋们,都有实质性的提高。

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 变量中。

  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<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应用中进行数据统计和展示的基本方法,并能够将其应用到实际项目中。希望本教程对您有所帮助!

本篇关于《JTable数据求和显示到文本框方法》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

CSS盒子美化:border-color与border-style技巧CSS盒子美化:border-color与border-style技巧
上一篇
CSS盒子美化:border-color与border-style技巧
中国移动宽带缴费方法及渠道汇总
下一篇
中国移动宽带缴费方法及渠道汇总
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3185次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    3396次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    3428次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    4534次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    3806次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码