栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java Excel操作相关工具类

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java Excel操作相关工具类

导包
		
        
            com.alibaba
            easyexcel
            3.0.4
            
                
                    org.apache.poi
                    poi-ooxml
                
            
        
        
            org.apache.poi
            poi
            4.1.2
        
        
            org.apache.poi
            poi-ooxml
            4.1.2
        
工具类
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;


public class YcsExcelUtils {
    
    public static List> parseToContent(InputStream inputStream) {
        List> result = new ArrayList<>();
        EasyExcel.read(inputStream, new ContentListener(result)).sheet().doRead();
        return result;
    }

    
    public static  List parseToObject(InputStream inputStream, Class type) {
        List result = new ArrayList<>();
        EasyExcel.read(inputStream, type, new ObjectListener(result)).sheet().doRead();
        return result;
    }

    
    public static  void objectToExcel(Class type, List data, OutputStream outputStream) {
        EasyExcel.write(outputStream, type).sheet().doWrite(data);
    }

    
    public static void contentToExcel(List> head, List> data, OutputStream outputStream) {
        EasyExcel.write(outputStream).head(head).sheet().doWrite(data);
    }
}

class ObjectListener extends AnalysisEventListener {

    private final List result;

    public ObjectListener(List result) {
        this.result = result;
    }

    @Override
    public void invoke(T t, AnalysisContext analysisContext) {
        result.add(t);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {

    }
}

class ContentListener extends AnalysisEventListener> {
    private final List> result;

    public ContentListener(List> result) {
        this.result = result;
    }

    @Override
    public void invoke(Map rowMap, AnalysisContext analysisContext) {
        Set colIndexSet = rowMap.keySet();
        List rowList = new ArrayList<>();
        for (int colIndex : colIndexSet) {
            rowList.add(rowMap.get(colIndex));
        }
        result.add(rowList);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {

    }
}

测试
public class SelfTest {
    private File desktopDir;
    
    private String desktopPath;

    @Before
    public void desktopDirTest() {
        desktopDir = FileSystemView.getFileSystemView().getHomeDirectory();
        desktopPath = desktopDir.getAbsolutePath();
    }

	@Test
    public void ExcelUtils() throws FileNotFoundException {
        InputStream inputStream = new FileInputStream(desktopPath + "/year.xlsx");
        List> lists = YcsExcelUtils.parseToContent(inputStream);
        System.out.println(JSON.toJSONString(lists));
        List channelInits = YcsExcelUtils.parseToObject(inputStream, ChannelInit.class);
        System.out.println(JSON.toJSONString(channelInits));
    }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/679081.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号