Java Swing使用POI生成用户命名的excel文件

	public void saveFile() {
		//弹出文件选择框
		JFileChooser chooser = new JFileChooser();
		
		//后缀名过滤器
		FileNameExtensionFilter filter = new FileNameExtensionFilter(
		        "(*.xlsx)", "xlsx");
		chooser.setFileFilter(filter);
		
		//下面的方法将阻塞,直到【用户按下保存按钮且“文件名”文本框不为空】或【用户按下取消按钮】
		int option = chooser.showSaveDialog(null);
		if(option==JFileChooser.APPROVE_OPTION){	//假如用户选择了保存
			File file = chooser.getSelectedFile();
			
			String fname = chooser.getName(file);	//从文件名输入框中获取文件名
			
			//假如用户填写的文件名不带我们制定的后缀名,那么我们给它添上后缀
			if(fname.indexOf(".xlsx")==-1){
				file = new File(chooser.getCurrentDirectory(),fname+".xlsx");
				System.out.println("renamed"); 
				System.out.println(file.getName());
			}
			
			try {
		        String[] title = {"订单ID", "流水号"};
		        //创建HSSF工作薄
				XSSFWorkbook workbook = new XSSFWorkbook();
		        //创建一个Sheet页
		        XSSFSheet sheet = workbook.createSheet();
		        //创建第一行(一般是表头)
		        XSSFRow row0 = sheet.createRow(0);
		        //创建列
		        XSSFCell cell = null;
		        //设置表头
		        for (int i = 0; i < title.length; i++) {
		            cell = row0.createCell(i);
		            cell.setCellValue(title[i]);
		        }
		        //填充50行数据
		        for (int i = 1; i < 50; i++) {
		            XSSFRow row = sheet.createRow(i);
		            XSSFCell cell1 = row.createCell(0);
		            cell1.setCellValue(new Random().nextInt(10000) % (10000 - 10 + 1) + 10);
		            XSSFCell cell2 = row.createCell(1);
		            cell2.setCellValue(new Random().nextInt(10000) % (10000 - 10 + 1) + 10);
		        }
		        //保存到本地
		        FileOutputStream outputStream = new FileOutputStream(file);
		        //将Excel写入输出流中
		        workbook.write(outputStream);
		        outputStream.flush();
		        outputStream.close();
				
			} catch (IOException e) {
				e.printStackTrace();
			}	
		}
	}

直接调用即可。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值