利用模板导出文件(一)之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)
上一篇 2022年7月24日 下午12:16
下一篇 2022年7月24日 下午12:16


相关推荐

  • 『Logstash』Logstash配置文件详解

    『Logstash』Logstash配置文件详解读完这篇文章里你能收获到 Logstash 配置文件详解

    2026年3月19日
    2
  • 织梦dedecsm系统”企业简介”类单栏目模版如何修改和调用

    织梦dedecsm系统”企业简介”类单栏目模版如何修改和调用

    2021年9月22日
    45
  • 怎么修改WiFi频段_wifi5g与2.4g怎么切换

    怎么修改WiFi频段_wifi5g与2.4g怎么切换在网络应用中对带宽要求较高的在线视频、高清点播等业务,如果使用5GHz频段进行传输,无线连接稳定性和传输速速率将更有保障,在这里以TP-LINK双频无线路由器作为演示,教你如何设置使用5GHz频段无线路由器。下面以TL-WDR4310为例介绍双频无线路由器在5GHz频段下的设置步骤。步骤一:在浏览器的地址栏上输入“192.168.1.1”打开路由器管理界面,输入用户名和密码(默认均为“admin”…

    2022年10月20日
    4
  • python面板数据模型_面板数据模型选择

    python面板数据模型_面板数据模型选择面板数据模型选择一般而言 面板数据模型的误差项由两部分组成 一部分是与个体观察单位有关的 它概括了所有影响被解释变量 但不随时间变化的因素 因此 面板数据模型也常常被成为非观测效应模型 另外一部分概括了因截面因时间而变化的不可观测因素 通常被成为特异性误差或特异扰动项 事实上这第二部分误差还可分成两部分 一部分是不因截面变化但随时间变化的非观测因素对应的误差项 Vt 这一部分一般大家的处理办法是通

    2026年3月19日
    2
  • 上百例Silverlight网站及演示汇总「建议收藏」

    上百例Silverlight网站及演示汇总「建议收藏」SilverLight网站大集合1.国外的一家电视网站http://plus.mixplay.tv/videosonline/home#videos-de.home:plus 2.条形码http://www.neodynamic.com/demo-faq/barcode-silverlight/134/SilverlightBarcodePhotoIdCardOnline/Defa

    2022年10月19日
    6
  • 桌面cpu性能排行榜_19年cpu天梯图

    桌面cpu性能排行榜_19年cpu天梯图排名 处理器 图例 分数 1 IntelXeonPlatinum8173M@2.00GHz 28860 2 IntelXeonGold6154@3.00GHz 27789 3 IntelCorei9-7980XE@2.60GHz 27736 4 IntelXeonW-…

    2026年2月2日
    6

发表回复

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

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