java生成excel并导出到对应位置的方式
作者:Burton_J 发布时间:2021-12-30 16:05:14
标签:java,生成excel,导出,位置
生成excel并导出到对应位置
package tech.BurtonPratice;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
import java.io.File;
import java.io.FileOutputStream;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
@RunWith(JUnit4.class)
public class PoiExcel {
@Test
public void exportExcel() {
Map<String, Integer> accts = new HashMap<String, Integer>() {
{
put("123456", 125);
put("123451", 121);
put("123457", 124);
put("123459", 122);
}
};
// 创建HSSFWorkbook对象(excel的文档对象)
HSSFWorkbook wb = new HSSFWorkbook();
// 建立新的sheet对象(excel的表单)
HSSFSheet sheet = wb.createSheet("FXT");
// 在sheet里创建第一行,参数为行索引(excel的行),可以是0~65535之间的任何一个
HSSFRow row1 = sheet.createRow(0);
// 创建单元格(excel的单元格,参数为列索引,可以是0~255之间的任何一个
HSSFCell cellOne = row1.createCell(0);
// 设置单元格内容
cellOne.setCellValue("账号");
HSSFCell cellTwo = row1.createCell(1);
// 设置单元格内容
cellTwo.setCellValue("金额");
//行数
int rowNum = 1;
//遍历hashmap
Iterator iterator = accts.entrySet().iterator();
while (iterator.hasNext()) {
Map.Entry entry = (Map.Entry) iterator.next();
Object key = entry.getKey();
Object val = entry.getValue();
//创建一行行记录
rowNum++;
// 在sheet里创建下一行
HSSFRow newRow = sheet.createRow(rowNum);
// 创建单元格并设置单元格内容
newRow.createCell(0).setCellValue((String) key);
newRow.createCell(1).setCellValue((Integer) val);
}
// 第六步,将文件存到指定位置
try {
String path = "F:/a/b.xlsx";
File file = new File(path);
//如果已经存在则删除
if (file.exists()) {
file.delete();
}
//检查父包是否存在
File parentFile = file.getParentFile();
if (!parentFile.exists()) {
parentFile.mkdirs();
}
//创建文件
file.createNewFile();
FileOutputStream fout = new FileOutputStream(path);
wb.write(fout);
String str = "导出成功!";
System.out.println(str);
fout.close();
} catch (Exception e) {
e.printStackTrace();
String str1 = "导出失败!";
System.out.println(str1);
}
// 合并单元格CellRangeAddress构造参数依次表示起始行,截至行,起始列, 截至列
//sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 3));
}
}
生成excel图:
指定路径导入导出文件
使用JFileChooser ,可以弹出对话框,然后选择指定路径上的文档。
读取指定路径下的文件
private JFileChooser fileChooser = new JFileChooser(".");
private void getInputFile() throws Exception {undefined
fileChooser.setFileSelectionMode(JFileChooser.FILES_ONLY);
fileChooser.setDialogTitle("选择输入Excel文件");
int ret = fileChooser.showOpenDialog(null);
if (ret == JFileChooser.APPROVE_OPTION) {undefined
File inputFile = fileChooser.getSelectedFile().getAbsoluteFile();
FileInputStream input = new FileInputStream(inputFile );
// 然后根据实际情况去操作input即可。
}
}
将文件导出至指定路径
private boolean getOutputPath() {undefined
boolean pathFlg = true;
fileChooser.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY);
fileChooser.setDialogTitle("选择文件导出的路径");
int ret = fileChooser.showOpenDialog(null);
if (ret == JFileChooser.APPROVE_OPTION) {undefined
String outFile = fileChooser.getSelectedFile().getAbsolutePath();
System.out.println("fileChooser.outFile:" + outFile);
// outFile可选择的路径。
} else {undefined
pathFlg = false;
}
return pathFlg;
}
来源:https://blog.csdn.net/weixin_37739042/article/details/88797101


猜你喜欢
- 本文实例讲述了Java TreeSet实现学生按年龄大小和姓名排序的方法。分享给大家供大家参考,具体如下:import java.util.
- 背景客户使用我们系统的时候,查询不带任何查询条件,查询就返回全部数据,500多万条数据啊,然后直接导出,数据量庞大,接口超时,这可苦了我们这
- 看到某些App里面有读取联系人的功能,然后自己尝试了一下。发现这个挺简单的。然后自己就做了一个demo给大家,希望借这个demo可以让大家学
- SpringBoot JPA分页查询指定列并返回指定实体用习惯Mybatis,没用过jpa 真是各种踩坑了脑壳疼,一个分页弄老半天,原来就一
- 一、前言用过Spring Cloud的同学都知道在使用动态配置刷新的我们要配置一个@RefreshScope 在类上才可以实现对象属性的的动
- 1.问题产生情况我遇到这个问题是做微信开发的时候有些有用的头像用了微信的emoji表情,然而我的mysql数据库用的编码是utf8_gene
- 本文实例为大家分享了java实现上传网络图片到微信临时素材的具体代码,供大家参考,具体内容如下package org.afuos.playc
- 本文实例展示了C#实现Datatable排序的方法,分享给大家供大家参考之用。具体方法如下:一般来说,在C#中要对Datatable排序,可
- C语言中的数组索引必须保证位于合法的范围内!示例代码如下:enum {TABLESIZE = 100};int *table = NULL;
- 日期显示和选择类库,可以用来选择一段连续的和多个不连续的日期,具体的UI完全抽象出来了,可以高度自定义(GITHUB地址)支持的功能:1、选
- 一直使用的是FastJson,感觉还不错,很方便。看了一段别人的分析,觉得很有道理。为什么要使用Fastjson,其实原因不需要太多,喜欢就
- Java常用类String类概述String类:代表字符串。Java程序中的所有字符串字面值(如:”abc“)都作为子类的实例实现Strin
- 特简单, 没有数据库, 还没有处理各种异常。登录:输入用户名点击的登录即可。发送消息: 特定格式->toUser:message1.
- 前言本文给大家分享一个使用Android开发写字板功能Dem、简单操作内存中的图像、对图像进行简单的处理、绘制直线、以达到写字板的效果效果图
- 前言用过Spring的人多多少少也都用过@Async注解,至于作用嘛,看注解名,大概能猜出来,就是在方法执行的时候进行异步执行。一、如何使用
- 本文实例讲述了Java实现的RSA加密解密算法。分享给大家供大家参考,具体如下:import java.awt.AlphaComposite
- 本文实例为大家分享了使用aop实现全局异常处理的具体代码,供大家参考,具体内容如下日常业务中存在的问题使用大量的try/catch来捕获异常
- 前言最近在使用Spring框架时遇到了一些问题,主要是Spring的事务传播问题,一个不带事务的方法调用带事务的方法,有时候会出现不回滚的情
- 概述从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章.获取哈希值hashCode()方法可以返回一个对象的哈希
- 本文实例讲述了C#多线程处理多个队列数据的方法。分享给大家供大家参考。具体实现方法如下:using System;using System.