您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)POI復(fù)制EXCEL單元格樣式失敗怎么辦,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
XSSFCell復(fù)制單元格樣式的兩種方式
1、直接將原單元格樣式加載新建單元格上
XSSFRow newRow = sheet.createRow(row + 5); for (int cell = 0; cell < maxCellNum; cell++) { XSSFCell newCell = newRow.createCell(cell); newCell.setCellStyle(sheet.getRow(5).getCell(cell).getCellStyle()); }
2、使用CellStyle的cloneStryleFrom方法復(fù)制一個新的樣式
XSSFRow newRow = sheet.createRow(row + 5); for (int cell = 0; cell < maxCellNum; cell++) { XSSFCell newCell = newRow.createCell(cell); CellStyle cStyle = workbook.createCellStyle(); cStyle.cloneStyleFrom(newCell.getCellStyle()); newCell.setCellStyle(cStyle); }
一般情況推薦使用第二種方法,方法一可能會出現(xiàn)單元格樣式被覆蓋的情況。
問題背景:通過excel的模版,將具體數(shù)據(jù)填充入對應(yīng)的單元格中生成一份商品清單的文件。模版如下(為了直觀,特意將最后兩列背景顏色設(shè)置成橙、紅,便于對比)
最終生成excel文件如下
本次遇到的問題是不管使用上述任何一種方法都無法正常給單元格加樣式。
經(jīng)過排查發(fā)現(xiàn)是因為在給每行最有一個單元格添加樣式之后沒有為它進行賦值,因此樣式不會生效,必須要對每行最后一個添加樣式的單元格進行賦值,樣式才會正常顯示。
excelRow.getCell(10).setCellValue("");
經(jīng)過修改后導(dǎo)出文件如下
看完上述內(nèi)容,你們對POI復(fù)制EXCEL單元格樣式失敗怎么辦有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。