java实现自定义导出模板

java实现自定义导出Excel模板

​ 由于最近用户经常提出导出Excel的格式进行调整,包括列的前后位置,增加字段等等。比如调整位置,不但需要调整表头,还要调整表头下面所对应的内容也要一块调整,所以想对这个功能进行一个改造。因为我是使用的springboot, 有一些方法是使用到spring组件里的方法。这里我大致将实现方法记录如下,省去了SpringBoot组件中的一些内容。

  1. 这里的模板我使用的是xml, 所以需要使用到解析xml相关的一些jar包,所以需要使用到的一些Maven依赖:
   <dependency>
           <groupId>com.google.guava</groupId>
           <artifactId>guava</artifactId>
           <version>19.0</version>
    </dependency>	

   <dependency>
       <groupId>org.apache.poi</groupId>
       <artifactId>poi</artifactId>
       <version>4.1.2</version>
   </dependency>
   
   <dependency>
       <groupId>org.apache.poi</groupId>
       <artifactId>poi-ooxml</artifactId>
       <version>4.1.2</version>
   </dependency>
   
   <dependency>
       <groupId>dom4j</groupId>
       <artifactId>dom4j</artifactId>
       <version>1.6.1</version>
   </dependency>
   
   <dependency>
       <groupId>jaxen</groupId>
       <artifactId>jaxen</artifactId>
       <version>1.2.0</version>
   </dependency>
   
   <dependency>
       <groupId>org.apache.commons</groupId>
       <artifactId>commons-lang3</artifactId>
       <version>3.11</version>
   </dependency>
   
   <dependency>
       <groupId>com.alibaba</groupId>
       <artifactId>fastjson</artifactId>
       <version>1.2.75</version>
   </dependency>

  1. 首先定义一个模板,.创建UserList.xml:
<?xml version="1.0" encoding="UTF-8"?>
<table filename="UserList" sheetname="detail">
    <column name="name" title="User Name" index="0" width="30"/>
	<column name="tel" title="Telphone" index="1" width="30"/>
    <column name="address" title="Address" index="2"  width="30"/>
</table>

filename: 这个是导出时候的文件名字

sheetname: sheet的名字

column.name: 对应导出实体的属性名字,到时通过取这个属性对应的value

​ column.title: Excel表的title

​ index: 表头所在的位置

​ width: 表头的宽度

  1. 接下来创建一个读取Xml文件的内容,并进行封装。

    import java.io.File;
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.Iterator;
    import java.util.List;
    import org.dom4j.Attribute;
    import org.dom4j.Document;
    import org.dom4j.DocumentException;
    import org.dom4j.Element;
    import org.dom4j.io.SAXReader;
    
    public class XMLUtil {
    	
        public static HashMap getConfig(String src){
            HashMap result = new HashMap();
            SAXReader reader = new SAXReader();
            Document document = null;
            
            try{
                document = reader.read(new File(src));
            }
            catch (DocumentException e1)
            {
                e1.printStackTrace();
            }
            Element root = document.getRootElement();
            String sheetName = root.attributeValue("sheetname");
            String fileName = root.attributeValue("filename");
            result.put("sheetname", sheetName);
            result.put("filename", fileName);
            List columns = root.elements("column");
            ArrayList<HashMap> config = new ArrayList<HashMap>();
            for(Iterator car = columns.iterator(); car.hasNext();){
                Element e = (Element)car.next();
                HashMap child = new HashMap();
                for(Iterator tank = e.attributes().iterator();tank.hasNext();){
                    Attribute attr  = (Attribute)tank.next();
                    child.put(attr.getName(), attr.getStringValue());
                }
                config.add(child);
            }
            result.put("list", config);
            return result;
        }
    
    }
    
  2. 创建生成Excel的工具类

    import java.io.File;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.Iterator;
    import java.util.List;
    import java.util.Map;
    import java.util.concurrent.TimeUnit;
    import org.apache.poi.ss.usermodel.BorderStyle;
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.CellStyle;
    import org.apache.poi.ss.usermodel.CellType;
    import org.apache.poi.ss.usermodel.Font;
    import org.apache.poi.ss.usermodel.HorizontalAlignment;
    import org.apache.poi.ss.usermodel.Row;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.xssf.streaming.SXSSFWorkbook;
    import com.alibaba.fastjson.JSONObject;
    import com.google.common.base.Stopwatch;
    
    public class ExcelExportUtils {
    	
        public static void export(List sourceData, String xmlPath, String targetPath){
        	Stopwatch executeWatch = Stopwatch.createStarted();
        	FileOutputStream fos = null;
        	SXSSFWorkbook wb = null;
            try {
            	
            	File targetFile = new File(targetPath);
            	
                HashMap result = XMLUtil.getConfig(xmlPath);
                ArrayList<HashMap> config = (ArrayList<HashMap>) result.get("list");
                wb = new SXSSFWorkbook();
                Sheet sheet = wb.createSheet(result.get("sheetname") + "");
                Row row = null;
                Map tds = null;
                Cell cell = null;
                int index = 0;
                Map.Entry<String, Object> entry = null;
                HashMap configSingle = null;
                
                if (config != null && config.size() > 0) {
                    row = sheet.createRow(0);
                    row.setHeight((short) 600);
                    CellStyle style = wb.createCellStyle();
                    Font f = wb.createFont();
                    f.setFontHeightInPoints((short) 11);
                    f.setBold(true);
                    style.setFont(f);
                    style.setAlignment(HorizontalAlignment.CENTER);
                    style.setBorderBottom(BorderStyle.DOTTED);
                    //创建表头
                    for (HashMap map : config) {
                        cell = row.createCell(Integer.parseInt(map.get("index") + ""), CellType.STRING);
                        cell.setCellStyle(style);
                        cell.setCellValue(map.get("title") + "");
                        if (org.apache.commons.lang3.StringUtils.isNotBlank(map.get("width").toString())) {
                            sheet.setColumnWidth(new Short(map.get("index") + "").shortValue(), new Short(map.get("width") + "").shortValue() * 256);
                        }
                    }
                    
                    //创建各个值的Cell,并赋值
                    if(null != sourceData && sourceData.size() > 0){
    	                for (int i = 0; i < sourceData.size(); i++) {
    	                    row = sheet.createRow(i + 1);
    	                    row.setHeight((short) 500);
    	                    String s = JSONObject.toJSONString(sourceData.get(i));
    	                    tds = JSONObject.parseObject(s, Map.class);
    	                    for (HashMap map : config) {
    	                        for (Iterator car = tds.entrySet().iterator(); car.hasNext(); ) {
    	                            entry = (Map.Entry<String, Object>) car.next();
    	                            if (map.get("name").equals(entry.getKey())) {
    	                                cell = row.createCell(Integer.parseInt(map.get("index") + ""), CellType.STRING);
    	                                cell.setCellStyle(style);
    	                                cell.setCellValue(entry.getValue() + "");
    	                            }
    	                        }
    	                    }
    	                }
    	                
    	                fos = new FileOutputStream(targetFile);
    	                wb.write(fos);
    	                executeWatch.stop();
    	                
    	                System.out.println("共执行多久:" + executeWatch.elapsed(TimeUnit.MILLISECONDS));
    	                
                    }
                    
                }
            } catch (Exception e) {
                e.printStackTrace();
            }finally {
            	try {
                    if(wb != null) {
                        //处理SXSSFWorkbook导出excel时,产生的临时文件
                        wb.dispose();
                    }
                    if(fos != null) {
                        fos.close();
                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
    
    
  3. 创建个测试类,测试是否成功

    import java.util.ArrayList;
    import java.util.List;
    
    public class Test {
    	
    	public static void main(String[] args) {
    		String xmlPath = "E:\\UserList.xml";
    		String targetPath = "E:\\UserList.xlsx";
    		List<User> users = new ArrayList<User>();
    		User user = null;
    		
    		for(int i = 1; i < 101; i++) {
    			user = new User("name"+i, "0755-0"+i, "深圳市龙岗区坂田街道"+i);
    			users.add(user);
    		}
    		
    		ExcelExportUtils.export(users, xmlPath, targetPath);
    	}
    }
    
    class User{
    	private String name;
    	
    	private String tel;
    	
    	private String address;
    	
    	public User() {
    		super();
    	}
    
    	public User(String name, String tel, String address) {
    		super();
    		this.name = name;
    		this.tel = tel;
    		this.address = address;
    	}
    
    	public String getName() {
    		return name;
    	}
    
    	public void setName(String name) {
    		this.name = name;
    	}
    
    	public String getTel() {
    		return tel;
    	}
    
    	public void setTel(String tel) {
    		this.tel = tel;
    	}
    
    	public String getAddress() {
    		return address;
    	}
    
    	public void setAddress(String address) {
    		this.address = address;
    	}
    }
    
    

    导入效果如图,看着还可以。

在这里插入图片描述

注意:

  1. xml文件中的column name需要与实体属性的名称一致。
  2. 这个实现的比较简陋,可以在column标记中增加一些其他属于,比如样式、时间转换等功能
  3. 如果需要调整位置,只需要调整column中的index属性即可,不再需要同时调整表头和内容
  4. 当然也可以在此基础上面进行一些增强,比如合并列之类的,后期有时间我再想想如何对这个模板进行改造下吧
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值