利用模板导出文件(一)之XLSTransformer导出excel文件

利用模板导出文件(一)之XLSTransformer导出excel文件由于现在好多公司都在实行办公无纸化操作,所以一般都是使用excel以及word来办公,本文是公司项目中使用excel文件模板生成对应的文件:首先,需要导入一下几个包:接下来就是具体的代码:importjava.io.File;importjava.io.IOException;importjava.util.ArrayList;importjava.util.Has

大家好,又见面了,我是你们的朋友全栈君。

由于现在好多公司都在实行办公无纸化操作,所以一般都是使用excel以及word来办公,本文是公司项目中使用excel文件模板生成对应的文件:

首先,需要导入一下几个包:

利用模板导出文件(一)之XLSTransformer导出excel文件

接下来就是具体的代码:


import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.swing.JOptionPane;

import net.sf.jxls.exception.ParsePropertyException;
import net.sf.jxls.transformer.XLSTransformer;
/**
 * 利用模板导出excel文件
 * @typename:XLSTransformerExport
 * @author: FishRoad
 * @since: 2015年8月24日 下午1:35:29
 *
 */
public class XLSTransformerExport {
	
	public static void main(String []args){
		//组织数据
		 List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
	      Map<String, Object> m1 = new HashMap<String,Object>();
	      m1.put("PRONAME", "项目1");
	      m1.put("PLANTYPE", "计划1");
	      m1.put("PROTYPE", "类别1");
	      Map<String, Object> m2 = new HashMap<String,Object>();
	      m2.put("PRONAME", "项目2");
	      m2.put("PLANTYPE", "计划2");
	      m2.put("PROTYPE", "类别2");
	      
	      list.add(m1);
	      list.add(m2);
	      Map<String, Object> para = new HashMap<String, Object>();
	      para.put("result", list);
	      XLSTransformer transformer = new XLSTransformer();
	      
	      //String temppath = "C:\\Users\\Administrator\\Documents\\测试模板.xlsx";
	      //模板路径,如果用的模板是xlsx,则生成的文件类型也必须为xlsx类型,否则由于格式不对,会打不开文件
	      String temppath = "C:\\Users\\Administrator\\Documents\\测试模板_xls.xls";
	      //输出文件路径,以及路径名称
	      String exportpath =UtilTools.getDirPath("测试结果_xls.xls", new File("C:\\Users\\Administrator\\Documents"));
	      System.out.println(exportpath);
	      try {
	    	  //利用transformXLS来输出文件
			transformer.transformXLS(temppath, para,exportpath);
			//生成文件后提示是否立即打开该文件
	        if(JOptionPane.showConfirmDialog(null, "导出成功,是否打开文件?")==0){
	        	UtilTools.openDirFile(exportpath);
	        }
	        
		} catch (ParsePropertyException e) {
			System.out.println("失败!");
		} catch (IOException e) {
			System.out.println("失败!");
		}
	      
	}
	
	 

}

用到的工具类:

 /**
     * 保存文件的时候指定文件名和文件的保存路径
     * @param filename
     * @param path
     * @return
     */
    public static String getDirPath(String filename, File path) {
        JFileChooser parseDir = new JFileChooser();
        parseDir.setCurrentDirectory(path);
        parseDir.setAcceptAllFileFilterUsed(false);
        parseDir.setSelectedFile(new File(filename));
        int result = parseDir.showSaveDialog(null);
        if (result == JFileChooser.APPROVE_OPTION) {
            return parseDir.getSelectedFile().getAbsolutePath();
        } else {
            return "";
        }
    }

/**
	 * 打开文件所在的目录
	 * 
	 * @param destFileName
	 * @throws IOException
	 */
	public static void openDirFile(String destFileName) throws IOException {
		File file = new File(destFileName);
		java.awt.Desktop.getDesktop().open(file);
		//

	}

模板样式如下:

利用模板导出文件(一)之XLSTransformer导出excel文件

到此,整个项目就基本完成,然后运行结果如下:

利用模板导出文件(一)之XLSTransformer导出excel文件

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163875.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SQL之CASE WHEN用法详解

    SQL之CASE WHEN用法详解简单CASEWHEN函数:CASESCOREWHEN’A’THEN’优’ELSE’不及格’ENDCASESCOREWHEN’B’THEN’良’ELSE’不及格’ENDCASESCOREWHEN’C’THEN’中’ELSE’不及格’END等同于,使用CASEWHEN条件表达式函数实现:CASEWHENSCORE=’A’……

    2022年6月21日
    28
  • Android Studio新手教程「建议收藏」

    Android Studio新手教程「建议收藏」AndroidStudio下载选择从AndroidStudio中文组官网进行下载:http://www.android-studio.org/如果电脑网络好,能翻墙的,可以直接从官网首页推荐的google正版链接进行下载,如:android-studio-ide-173.4720617-windows.exeRecommended如果网络不好下载失败,则可以从官方提供的百度网盘方式进行下载:http://www.android-studio.org/index.php/downloa

    2022年4月27日
    69
  • 政府大数据应用案例,政府大数据治理方法[通俗易懂]

    政府大数据应用案例,政府大数据治理方法[通俗易懂]​大数据不仅将改变生产方式、生活方式,社会组织方式尤其是政府治理也将因之发生深刻变革。以大数据提升政府治理能力是大势所趋。科技革命的加速推进特别是大数据时代的到来,迫切要求政府治理加快。大数据将成为加快政府治理能力现代化的最重要、最有力推手。在大数据思维下,基于大数据的科学决策、精细管理、精准服务将成为常态,将大大推动政府管理理念和社会治理模式进步,推进法治政府、创新政府、廉洁政府、智慧政府和服务型政府建设,逐步实现治理能力现代化。政府如何利用大数据提升治理水平?1.用数据说话治理理念的转变是提高政府

    2022年6月4日
    45
  • echart中折线图data为“”时 线还连着 并为0

    echart中折线图data为“”时 线还连着 并为0

    2020年11月9日
    192
  • Java SSM框架简介[通俗易懂]

    Java SSM框架简介[通俗易懂]前言:在学习JavaSSM框架前,我提前学习了反射、注解和MVC模式,因为它们频繁在SSM框架中被用到,建议大家先弄明白了这些基础知识,再学习SSM框架就很简单了。Java进阶知识1:反射机制Java进阶知识2:注解MVC模式的正确理解一、JavaSSM框架的概念JavaSSM框架即指Spring+SpringMVC+MyBatis的简称,框架集由Spring、MyB…

    2022年7月12日
    16

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号