温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java怎么生成excel并导出到对应位置

发布时间:2022-02-07 15:37:21 来源:亿速云 阅读:178 作者:iii 栏目:开发技术

本篇内容介绍了“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图:

java怎么生成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;     }

“java怎么生成excel并导出到对应位置”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI