Java 操作POI 之复制sheet页

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

来点干货直接上代码,就不细说了

package com.qs.web.tools.core.excel;

import java.util.HashMap;

import java.util.Map;

import java.util.Set;

import java.util.TreeSet;


import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.ss.util.CellRangeAddress;


public   class ExcelCopySheetUtil {  

  

    public ExcelCopySheetUtil() {  

    }  

  

    public static void copySheets(HSSFSheet newSheet, HSSFSheet sheet) {  

        copySheets(newSheet, sheet, true);  

    }  

  

    public static void copySheets(HSSFSheet newSheet, HSSFSheet sheet,  

            boolean copyStyle) {  

        int maxColumnNum = 0;  

        Map<Integer, HSSFCellStyle> styleMap = (copyStyle) ? new HashMap<Integer, HSSFCellStyle>()  

                : null;  

        for (int i = sheet.getFirstRowNum(); i <= sheet.getLastRowNum(); i++) {  

            HSSFRow srcRow = sheet.getRow(i);  

            HSSFRow destRow = newSheet.createRow(i);  

            if (srcRow != null) {  

                ExcelCopySheetUtil.copyRow(sheet, newSheet, srcRow, destRow,  

                        styleMap);  

                if (srcRow.getLastCellNum() > maxColumnNum) {  

                    maxColumnNum = srcRow.getLastCellNum();  

                }  

            }  

        }  

        for (int i = 0; i <= maxColumnNum; i++) {    //设置列宽  

            newSheet.setColumnWidth(i, sheet.getColumnWidth(i));  

        }  

    }  

  

    /** 

     * 复制并合并单元格 

     * @param  newSheet 

     * @param  sheet 

     * @param  copyStyle 

     */  

    public static void copyRow(HSSFSheet srcSheet, HSSFSheet destSheet,  

            HSSFRow srcRow, HSSFRow destRow,  

            Map<Integer, HSSFCellStyle> styleMap) {  

        Set<CellRangeAddressWrapper> mergedRegions = new TreeSet<CellRangeAddressWrapper>();  

        destRow.setHeight(srcRow.getHeight());  

        int deltaRows = destRow.getRowNum() - srcRow.getRowNum(); //如果copy到另一个sheet的起始行数不同  

        for (int j = srcRow.getFirstCellNum(); j <= srcRow.getLastCellNum(); j++) {  

            HSSFCell oldCell = srcRow.getCell(j); // old cell  

            HSSFCell newCell = destRow.getCell(j); // new cell  

            if (oldCell != null) {  

                if (newCell == null) {  

                    newCell = destRow.createCell(j);  

                }  

                copyCell(oldCell, newCell, styleMap);  

                CellRangeAddress mergedRegion = getMergedRegion(srcSheet,  

                        srcRow.getRowNum(), (short) oldCell.getColumnIndex());  

                if (mergedRegion != null) {  

                    CellRangeAddress newMergedRegion = new CellRangeAddress(  

                            mergedRegion.getFirstRow() + deltaRows,  

                            mergedRegion.getLastRow() + deltaRows, mergedRegion  

                                    .getFirstColumn(), mergedRegion  

                                    .getLastColumn());  

                    CellRangeAddressWrapper wrapper = new CellRangeAddressWrapper(  

                            newMergedRegion);  

                    if (isNewMergedRegion(wrapper, mergedRegions)) {  

                        mergedRegions.add(wrapper);  

                        destSheet.addMergedRegion(wrapper.range);  

                    }  

                }  

            }  

        }  

    } 

  

    /** 

     * 把原来的Sheet中cell(列)的样式和数据类型复制到新的sheet的cell(列)中      *  

     * @param  oldCell 

     * @param  newCell 

     * @param styleMap 

     */  

    public static void copyCell(HSSFCell oldCell, HSSFCell newCell,  

            Map<Integer, HSSFCellStyle> styleMap) {  

        if (styleMap != null) {  

            if (oldCell.getSheet().getWorkbook() == newCell.getSheet()  

                    .getWorkbook()) {  

                newCell.setCellStyle(oldCell.getCellStyle());  

            } else {  

                int stHashCode = oldCell.getCellStyle().hashCode();  

                HSSFCellStyle newCellStyle = styleMap.get(stHashCode);  

                if (newCellStyle == null) {  

                    newCellStyle = newCell.getSheet().getWorkbook()  

                            .createCellStyle();  

                    newCellStyle.cloneStyleFrom(oldCell.getCellStyle());  

                    styleMap.put(stHashCode, newCellStyle);  

                }  

                newCellStyle.setLocked(false);

                newCell.setCellStyle(newCellStyle);  

            }  

        }  

        switch (oldCell.getCellType()) {  

        case HSSFCell.CELL_TYPE_STRING:  

            newCell.setCellValue(oldCell.getStringCellValue());  

            break;  

        case HSSFCell.CELL_TYPE_NUMERIC:  

            newCell.setCellValue(oldCell.getNumericCellValue());  

            break;  

        case HSSFCell.CELL_TYPE_BLANK:  

            newCell.setCellType(HSSFCell.CELL_TYPE_BLANK);  

            break;  

        case HSSFCell.CELL_TYPE_BOOLEAN:  

            newCell.setCellValue(oldCell.getBooleanCellValue());  

            break;  

        case HSSFCell.CELL_TYPE_ERROR:  

            newCell.setCellErrorValue(oldCell.getErrorCellValue());  

            break;  

        case HSSFCell.CELL_TYPE_FORMULA:  

            newCell.setCellFormula(oldCell.getCellFormula());  

            break;  

        default:  

            break;  

        }  

  

    }  

  

    // 获取merge对象  

    public static CellRangeAddress getMergedRegion(HSSFSheet sheet, int rowNum,  

            short cellNum) {  

        for (int i = 0; i < sheet.getNumMergedRegions(); i++) {  

            CellRangeAddress merged = sheet.getMergedRegion(i);  

            if (merged.isInRange(rowNum, cellNum)) {  

                return merged;  

            }  

        }  

        return null;  

    }  

  

    private static boolean isNewMergedRegion(  

            CellRangeAddressWrapper newMergedRegion,  

            Set<CellRangeAddressWrapper> mergedRegions) {  

        boolean bool = mergedRegions.contains(newMergedRegion);  

        return !bool;  

    }  

  

}  


转载于:https://my.oschina.net/zhangdayue/blog/419354

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/297339.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Serverless 落地实践

.Net Core Serverless初体验什么是ServerlessServerless 是一个当今软件世界中比较新的话题。它并没有一个普遍公认的权威定义&#xff0c;每个人每个企业对它的解释可能都有不同&#xff0c;而 Serverless 正是在这种情况下不断发发展的。但是就算如此&#xff0c;有一些 Serv…

KOFLive Beta Daily-Scrum 9

组 员今天的工作进 度问 题明天的计划田 飞Work Item 38911&#xff1a;角色四照片拍摄 Work Item 38897:键盘输入人物四的图片已经导入&#xff0c;键盘三个连键检测完成还剩最后一个连键的检测Work Item 38911:拍摄人物角色五付 浩Work Item 37741:游戏主模块 Work Item 3889…

Dapr + .NET 实战(十-终篇)K8S运行Dapr

工作原理为了实现在k8s上安装Dapr&#xff0c;Dapr需要部署dapr-sidecar-injector、dapr-operator、dapr-placement和dapr-sentry服务。 dapr-operator: 管理组件(state stores, pub/subs, etc.)dapr-sidecar-injector: 将 Dapr 注入 annotated pods&#xff0c;并添加环境变量…

mvc control 请求两次问题

今天在做项目时&#xff0c;突然发现一个mvc 的control中action被执行了两次&#xff0c;最终发现是由于favicon.ico导致的。问题代码&#xff1a; <link rel"shortcut icon" href"Images/wangyi.ico" type"image/x-icon" />,最终改成了 &…

为什么老师批改完试卷,分数下要画两条横线?今天终于知道了!

全世界只有3.14 % 的人关注了爆炸吧知识总有考试分数下画两条横线的习惯&#xff0c;原来是这样形成的&#xff01;为什么老师改卷之后会在分数下画两条横线呢&#xff1f;你要去问老师&#xff1f;别问了&#xff0c;可能连老师都不知道……来看看这位当了老师的网友怎么说的&…

Windows 11 小技巧- WSL开启Linux桌面应用

WSL 经过⼏年的发展&#xff0c;已经是⼀个Windows下不少开发⼈员做云原⽣应⽤的必备环境&#xff0c;你可以在上⾯写各种语⾔&#xff0c;各种后端框架&#xff0c;也可以完成容器和k8s的部署&#xff0c;在Windows11下更进⼀步&#xff0c;直接⽀持Linux桌⾯应⽤&#xff0c;…

lcd屏幕抖动_电视屏幕面板大科普!买电视之前必看!

BOE知识酷 ?显示技术|显示资讯| PPT|知识管理第856篇推文导读&#xff1a;经常看到什么LCD、LED、OLED、ULED、QLED、SLED、GLED……之类的名词&#xff0c;花里胡哨。别看那么多名词&#xff0c;但从显示技术角度看&#xff0c;现在市场上主流的电视机其实就两种&#xff1a;…

一击即中的表白方式,学会了吗?

1 自己吃自己的&#xff0c;敢抢我吃的&#xff0c;吃我的小拳拳&#xff01;2 承受了太多哈哈哈3 狗狗在你不知道的时候会默默守护你4 眼前的方不是方。。5 一击即中的表白方式&#xff0c;学会了吗&#xff1f;&#xff1f; 图自甜星球日报社6 哦…了解了图自迷影心生 7 当90…

mysql2012用户名_SQL Server 登录名、服务器角色、用户名和数据库角色 --- 解释

1.一个数据库用户可以对应多个架构(架构是表容器)。架构里面包含的是数据库表。2.一个数据库角色有可能涉及多个架构。数据库角色对应的是权限。3.一个用户对应一个数据库角色。4.登录名与数据库用户在服务器级别是一对多的&#xff1b;在数据库级别是一对一的。服务器登录名&a…

Windows 11 正式版 ISO 镜像下载大全

Windows 11 ISO 镜像规格1.Windows 11 中文版文件大小&#xff1a;5.13 GB系统类型&#xff1a;64 位操作系统版本号&#xff1a;Windows 11 21H2发布日期&#xff1a;2021 年 10 月 5 日MD5: 68FB0CAD069CF82A9BA0996A6D3D112BSHA1: 9F602662FFAB0DF3B3A66FC6A42849BFFD3315A7…

于明:APU能否接力取代迟暮的X86?

图&#xff1a;AMD Fusion APU中国发布会 有作用力必然有反作用力&#xff0c;有光亮也必然有黑暗&#xff0c;有诚实也必然有欺骗&#xff0c;任何事物都具有两面性&#xff0c;而PC的核心处理器也不例外&#xff0c;存在着“真融合”与“假融合”之分。 就拿AMD(NYSE: AMD)在…

SQL Azure Reporting CTP

http://blogs.msdn.com/b/azchina/archive/2011/02/18/sql-azure-reporting-limited-ctp-arrived.a概念SQL Azure Reporting 把云端报表作为服务来提供&#xff0c;构建于SQL Server Reporting Services 和 SQL Azure 技术之上。诸如SQL Azure Reporting此类云端报表服务具有许…

Windows 11 小技巧- winget安装和维护应用程序

安装好Windows 11后&#xff0c;你可能需要为系统安装常⽤的⼯具&#xff0c;例如安装Visual Studio Code&#xff0c;Google Chrome &#xff0c;VLC Player 等应⽤。以往你可能需要⾃⼰去各大网站上安装。如果你曾经使⽤Linux, 你可以通过命令⾏⽅式用apt安装和维护很多的…

输出毫秒_自学单片机第十三篇上:单点输出

关注一下&#xff0c;更多精彩等着你&#xff01;打开之前的工程&#xff0c;当然新建也可以&#xff0c;具体步骤看之前的文章就行。因为是学习&#xff0c;所以也用不着总是新建工程&#xff0c;起名起一大堆&#xff0c;接下来&#xff0c;除非要用两个执行文件&#xff0c;…

Hadoop分布式文件系统:架构和设计要点

一、前提和设计目标 1、硬件错误是常态&#xff0c;而非异常情况&#xff0c;HDFS可能是有成百上千的server组成&#xff0c;任何一个组件都有可能一直失效&#xff0c;因此错误检测和快速、自动的恢复是HDFS的核心架构目标。 2、跑在HDFS上的应用与一般的应用不同&#xff0c;…

22张令人叹为观止的照片,你所未知的另一面

全世界只有3.14 % 的人关注了爆炸吧知识见惯了身边的平淡和琐碎&#xff0c;总要开阔眼界&#xff0c;长长见识。走&#xff0c;带你看震惊世界的22张照片&#xff0c;保准惊呆你&#xff01;1、你知道他们是如何安装那些巨大的电线塔的了吧&#xff1a;2、人体分离魔术&#x…

Windows 11 小技巧- WSL运行本地GPU算力

WSL 已经被很多开发⼈员⽤于云原⽣开发&#xff0c;但如果你像我每天要完成⼈⼯智能应⽤的 发&#xff0c;会⼀直希望能加上GPU算⼒&#xff0c;这样就不需要再去安装⼀台Linux的机器去做⼈⼯智能的⼯作了(毕竟很多的⼈⼯智能场景都是在Linux下完成的)。这次Windows 11 不仅⽀…

私房钱就藏在老婆眼皮底下

1 建议出一个藏私房钱的教程▼2 以前还是打飞的就这个价格&#xff0c;最多是个飞公交▼3 众所周知狗是不会剪视频的&#xff0c;所以是真的▼4 老实讲我小时候也幻想过这个操作▼5 这可真是一个悲伤的故事▼6 这可真是令人羡慕的发量▼7 退一步越想越气忍一时越想越亏▼…

19.Silverlight调用webservice上传多个文件

Silverlight不支持读写服务器端的硬盘&#xff0c;可是很多时候用户需要在Silverlight客户端往服务器端上传文件&#xff0c;那么本节将讲述 Silverlight中最简单的上传文件的方式&#xff1a;在Silverlight客户端将文件序列化为Byte[]字符组&#xff0c;然后服务器端使用 webS…

原创:PHP内核研究:HASH表和变量

PHP HASH表 在PHP中,所有的数据 无论变量,常量,类,属性 都用Hash表来实现. 先要说说 HASH表 [c]typedef struct bucket { ulong h; /* Used for numeric indexing */ uint nKeyLength; //key长度 void *p…