java swing 打开文件_java swing实现打开Excel文件并进行处理

这里选择Excel文件是业务需要,话不多说

1、引入对Excel处理的相关依赖

org.apache.poi

poi

3.16

org.apache.poi

poi-ooxml

3.16

2、进行swing的相关布局

7df950c909a091616c7b9bb723d61868.png

代码:

package com.mozarta;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.xssf.usermodel.XSSFSheet;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import javax.swing.;

import javax.swing.border.EmptyBorder;

import java.awt.;

import java.awt.event.ActionEvent;

import java.awt.event.ActionListener;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.util.ArrayList;

import java.util.List;

public class UITest extends JFrame {

private JButton btn;

private JPanel contentPane; //内容面板

private JTextField textField; //文本框

public UITest(){

setTitle("选择文件"); //设置窗体的标题

setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); //设置窗体退出时操作

setBounds(100, 100, 800, 400); //设置窗体位置和大小

contentPane=new JPanel(); //创建内容面板

contentPane.setBorder(new EmptyBorder(100,5,5,5)); //设置面板的边框

contentPane.setLayout(new BorderLayout(0,0)); //设置内容面板为边界布局

setContentPane(contentPane); //应用内容面板

JPanel panel1=new JPanel(); //新建面板用于保存文本框

panel1.setBounds(5,100,800,100);

contentPane.add(panel1,BorderLayout.NORTH); //将面板放置在边界布局的北部

textField=new JTextField(); //新建文本框

panel1.add(textField); //将文本框增加到面板中

textField.setPreferredSize(new Dimension (400,40));

final JButton btn=new JButton("选择文件");

btn.setPreferredSize(new Dimension (100,40));

panel1.add(btn);

btn.setBackground(Color.GREEN);

JPanel panel2=new JPanel(); //新建面板用于保存按钮

contentPane.add(panel2, BorderLayout.CENTER); //将面板放置在边界布局的中央

JButton okBtn=new JButton("确定");

okBtn.setPreferredSize(new Dimension(100,40));

panel2.add(okBtn);

setVisible(true);

btn.addActionListener(new ActionListener() {

public void actionPerformed(ActionEvent e) {

//按钮点击事件

JFileChooser chooser = new JFileChooser(); //设置选择器

chooser.setMultiSelectionEnabled(true); //设为多选

int returnVal = chooser.showOpenDialog(btn); //是否打开文件选择框

System.out.println("returnVal="+returnVal);

if (returnVal == JFileChooser.APPROVE_OPTION) { //如果符合文件类型

String filepath = chooser.getSelectedFile().getAbsolutePath(); //获取绝对路径

System.out.println(filepath);

textField.setText(filepath);

}

}

});

/* 确定点击 */

okBtn.addActionListener(new ActionListener() {

@Override

public void actionPerformed(ActionEvent e) {

String filepath=textField.getText();

if("".equals(filepath)||filepath==null){

JOptionPane.showMessageDialog(getContentPane(), "请先选择文件~",

"警告", JOptionPane.WARNING_MESSAGE);

return;

}

String suffix=filepath.substring(filepath.lastIndexOf(".")+1);

System.out.println(suffix);

if(!(suffix.equals("xlsx")||(suffix.equals("xls")))){

JOptionPane.showMessageDialog(getContentPane(), "请选择Excel文件~",

"警告", JOptionPane.WARNING_MESSAGE);

return;

}

/* 打开文件 */

try {

openFile(filepath);

} catch (Exception e1) {

e1.printStackTrace();

}

}

});

}

/* 打开对应的Excel文件 */

public void openFile(String filepath) throws IOException {

FileInputStream fileInputStream = new FileInputStream(new File(filepath));

XSSFWorkbook workbook = new XSSFWorkbook(fileInputStream);

XSSFSheet sheet = workbook.getSheetAt(0);

System.out.println(sheet.getLastRowNum());

queryRows(workbook,"设计");

}

/* 检索需要信息 */

public java.util.ListqueryRows(XSSFWorkbook workbook, String keys){

Listlist=new ArrayList<>();

XSSFSheet sheet = workbook.getSheetAt(0);

for(int i=2;i<=sheet.getLastRowNum();i++){

System.out.println(sheet.getRow(i).getCell(2).getStringCellValue());

if(sheet.getRow(i).getCell(2).getStringCellValue().contains(keys)){

list.add(sheet.getRow(i));

}

}

return list;

}

public static void main(String[] args) {

new UITest();

}

}

后续对Excel的处理可以用户自行实现,代码只是对选择的是否是Excel文件进行判断,并且根据业务需要都所打开的Excel文件进行检索。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/346741.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

@ParameterizedTest在@CvsSource中具有空值

在JUnit 4中编写参数化测试非常麻烦。 JUnit 5对框架进行了一些有用的改进&#xff0c;并且使用不同的参数运行相同的测试比以前的版本要简单得多。 但是&#xff0c;在这样的参数中传递空值存在一个小问题。 在这篇文章中&#xff0c;我将向您展示如何在JUnit 5中的Parametrz…

java正则断言_Java正则表达断言篇

正则表达式的先行断言和后行断言一共有4种形式&#xff1a;(?pattern) 零宽正向先行断言(zero-width positive lookahead assertion)(?!pattern) 零宽负向先行断言(zero-width negative lookahead assertion)(?<pattern) 零宽正向后行断言(zero-width positive lookbehin…

java的对象对象映射_Java对象到对象映射器

java的对象对象映射我在该项目上使用了Dozer一段时间。 但是&#xff0c;最近我遇到了一个非常有趣的错误&#xff0c;这促使我环顾四周&#xff0c;并尝试使用其他“对象到对象”映射器。 这是我找到的工具列表&#xff1a; 推土机&#xff1a;推土机是Java Bean到Java Bea…

java parallelstream_关于Java8 parallelStream并发安全的深入讲解

背景Java8的stream接口极大地减少了for循环写法的复杂性&#xff0c;stream提供了map/reduce/collect等一系列聚合接口&#xff0c;还支持并发操作&#xff1a;parallelStream。在爬虫开发过程中&#xff0c;经常会遇到遍历一个很大的集合做重复的操作&#xff0c;这时候如果使…

Jakarta EE,EE4J和Java EE之间的关系

Jakarta EE的名称已经存在了一个多月&#xff0c;即使Mike Milinkovich在他的博客文章“名称是……”中很好地解释了名称和概念&#xff0c;但对于它们之间的关系仍然有些困惑&#xff0c;我也提出了疑问只要有话题就可以围绕它。 我试图在这里总结一下。 希望能帮助到你&#…

java readline 超时_跳过Java中的BufferedReader readLine()方法

是否有一种简单的方法可以跳过java中的readLine()方法(如果它花费的时间超过2秒)&#xff1f;这是我问这个问题的背景&#xff1a;public void run(){boolean looping true;while(looping) {for(int x 0; xtry {Comm s clientList.get(x);String str s.recieve();// code t…

minwindow java_Java经典算法:最小窗口子字符串

给定一个字符串S和一个字符串T&#xff0c;找到S中的最小窗口&#xff0c;其中将包含T中所有字符的复杂度为O(n)。例如&#xff0c;S “ ADOBECODEBANC”&#xff0c;T “ ABC”&#xff0c;最小窗口为“ BANC”。Java解决方案public String minWindow(String s, String t) {Ha…

j2ee可以用于前端开发吗_用于J2EE开发的Cloud IDE

j2ee可以用于前端开发吗随着许多传统软件工具进入云计算&#xff0c;我想看看它们与传统工具的比较。 我的兴趣是J2EE技术​​&#xff0c;并开始寻找一种云服务&#xff0c;该服务使我能够开发&#xff0c;测试和部署J2EE应用程序。 我很快发现&#xff0c;许多云IDE是为Web前…

java为什么全是乱码_java一切乱码的解释 以及源头

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼InputStreamReader in new InputStreamReader(new FileInputStream(“demo.txt”),”UTF-8”);给InputStreamReader指定解码编码&#xff0c;这样二者统一就不会出现乱码了。下面说说字符输出流。字符输出流的原理和字符输入流的原…

JAVA连接数据库ij_Derby 客户端 ij使用

Derby是开源的、嵌入式的Java数据库程序&#xff0c;ij是Derby提供的客户端工具&#xff0c;相当于其他数据库提供的sqlplus工具。ij是纯Java的程序&#xff0c;不用安装&#xff0c;使用起来就像运行普通的Java应用程序一样。接下来说下&#xff1a;如何使用ij工具去操作数据库…

使用Google Cloud Storage托管您的Maven工件

如果您使用Google Cloud并将Java用于项目&#xff0c;那么Google Cloud Storage是托管团队工件的理想场所。 它很容易设置&#xff0c;而且很便宜。 如果您对它们的功能不特别感兴趣&#xff0c;那么它比设置现有存储库选项&#xff08;jfrog&#xff0c;nexus&#xff0c;arc…

java+map对象判断空值_java判断map中是否存在指定对象

Map判断是否包含指定的value使用containsValue方法。(推荐&#xff1a;java视频教程)定义containsValue(Object value) 如果此映射将一个或多个键映射到指定值&#xff0c;则返回 true示例&#xff1a;/**** Map集合判断是否包含value**/public class MapDemo{public static vo…

mysql 主主模式优缺点_mysql主主同步模式

主192.168.56.20 和 从都新建数据库db1 db2 db3(如果数据库在用&#xff0c;需要上锁后手动从主备份&#xff0c;然后在从恢复)mysql> create database db1;Query OK, 1 row affected (0.00 sec)mysql> create database db2;Query OK, 1 row affected (0.00 sec)mysql>…

spring 类型转换器_Spring中的类型转换

spring 类型转换器以下是一些需要类型转换的简单情况&#xff1a; 情况1。 为了帮助简化bean配置&#xff0c;Spring支持属性值与文本值之间的转换。 每个属性编辑器仅设计用于某些类型的属性。 为了使用它们&#xff0c;我们必须在Spring容器中注册它们。 案例2。 同样&…

java+语音识别+谷歌_JAVA使用谷歌语音识别API

我正在尝试使用谷歌语音识别API.这是我写的代码&#xff1a;有用.我从服务器得到答案&#xff1a;{"status":5,"id":"8803471b14a2310dfcf917754e8bd4a7-1","hypotheses":[]}现在的问题是“状态&#xff1a;5”.事实上,这里的状态代码…

java中对象字节数_JAVA中求解对象所占字节大小

该类为cache4j缓存框架中的工具类方法&#xff0c;该方法实现了两个接口接口1&#xff1a;计算对象在内存中所占字节数接口2&#xff1a;复制对象&#xff0c;实现深度克隆效果&#xff0c;实现原理为先序列化对象&#xff0c;然后在反序列化对象&#xff1b;返回一个新的对象&…

excel查重复_毕业季 | 如何降低论文的查重率

毕业季吾日三省吾身实验做完了吗&#xff1f;论文写完了吗&#xff1f;查重能通过吗&#xff1f;学术圈的前辈告诉我们&#xff0c;只有站在巨人的肩膀上才能看得更远。在撰写一篇论文时&#xff0c;为保证质量和可靠性&#xff0c;难免需要引用前人的成果&#xff0c;这也反映…

Sun过去的世界中的JDK 11和代理

使用JDK 11后&#xff0c;就sun.misc.Unsafe的第一种方法。 其中&#xff0c; defineClass方法已删除。 代码生成框架通常使用此方法在现有的类加载器中定义新的类。 尽管此方法易于使用&#xff0c;但它的存在也使JVM本质上不安全&#xff0c;正如其定义类的名称所暗示的那样。…

java中 private final_Java笔记:final与private关键字

记录一个有趣的现象&#xff0c;private修饰的方法子类是访问不了的&#xff0c;且类中所有private修饰的方法都隐式的指定为final(可以对private方法添加final修饰词&#xff0c;但是这并不能给该方法增加任何额外的意义)&#xff0c;final修饰的方法是不可以被重写的。但是如…

Java,JavaFX的流畅设计风格进度栏

按照承诺&#xff0c;刚刚发布的Java JavaFX主题JMetro 4.6版为进度栏带来了新样式。 进度栏有两种可能的状态&#xff1a;确定和不确定&#xff0c;新的JMetro版本具有这两种状态。 在本文中&#xff0c;我还将详细介绍一些我在JMetro中遵守的API设计原则。 JMetro API设计原…