|
|
@ -4,14 +4,15 @@ import java.io.File; |
|
|
|
import java.util.ArrayList; |
|
|
|
import java.util.ArrayList; |
|
|
|
import java.util.List; |
|
|
|
import java.util.List; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import com.alibaba.easyexcel.test.core.StyleTestUtils; |
|
|
|
import com.alibaba.easyexcel.test.util.TestFileUtil; |
|
|
|
import com.alibaba.easyexcel.test.util.TestFileUtil; |
|
|
|
import com.alibaba.excel.EasyExcel; |
|
|
|
import com.alibaba.excel.EasyExcel; |
|
|
|
import com.alibaba.excel.annotation.write.style.HeadFontStyle; |
|
|
|
import com.alibaba.excel.annotation.write.style.HeadFontStyle; |
|
|
|
import com.alibaba.excel.annotation.write.style.HeadStyle; |
|
|
|
import com.alibaba.excel.annotation.write.style.HeadStyle; |
|
|
|
import com.alibaba.excel.metadata.Head; |
|
|
|
import com.alibaba.excel.metadata.Head; |
|
|
|
|
|
|
|
import com.alibaba.excel.metadata.data.DataFormatData; |
|
|
|
import com.alibaba.excel.metadata.property.FontProperty; |
|
|
|
import com.alibaba.excel.metadata.property.FontProperty; |
|
|
|
import com.alibaba.excel.metadata.property.StyleProperty; |
|
|
|
import com.alibaba.excel.metadata.property.StyleProperty; |
|
|
|
import com.alibaba.excel.metadata.data.DataFormatData; |
|
|
|
|
|
|
|
import com.alibaba.excel.write.merge.LoopMergeStrategy; |
|
|
|
import com.alibaba.excel.write.merge.LoopMergeStrategy; |
|
|
|
import com.alibaba.excel.write.merge.OnceAbsoluteMergeStrategy; |
|
|
|
import com.alibaba.excel.write.merge.OnceAbsoluteMergeStrategy; |
|
|
|
import com.alibaba.excel.write.metadata.style.WriteCellStyle; |
|
|
|
import com.alibaba.excel.write.metadata.style.WriteCellStyle; |
|
|
@ -22,11 +23,17 @@ import com.alibaba.excel.write.style.column.SimpleColumnWidthStyleStrategy; |
|
|
|
import com.alibaba.excel.write.style.row.SimpleRowHeightStyleStrategy; |
|
|
|
import com.alibaba.excel.write.style.row.SimpleRowHeightStyleStrategy; |
|
|
|
|
|
|
|
|
|
|
|
import org.apache.poi.ss.usermodel.BorderStyle; |
|
|
|
import org.apache.poi.ss.usermodel.BorderStyle; |
|
|
|
|
|
|
|
import org.apache.poi.ss.usermodel.Cell; |
|
|
|
import org.apache.poi.ss.usermodel.FillPatternType; |
|
|
|
import org.apache.poi.ss.usermodel.FillPatternType; |
|
|
|
import org.apache.poi.ss.usermodel.Font; |
|
|
|
import org.apache.poi.ss.usermodel.Font; |
|
|
|
import org.apache.poi.ss.usermodel.HorizontalAlignment; |
|
|
|
import org.apache.poi.ss.usermodel.HorizontalAlignment; |
|
|
|
import org.apache.poi.ss.usermodel.IndexedColors; |
|
|
|
import org.apache.poi.ss.usermodel.IndexedColors; |
|
|
|
|
|
|
|
import org.apache.poi.ss.usermodel.Row; |
|
|
|
|
|
|
|
import org.apache.poi.ss.usermodel.Sheet; |
|
|
|
import org.apache.poi.ss.usermodel.VerticalAlignment; |
|
|
|
import org.apache.poi.ss.usermodel.VerticalAlignment; |
|
|
|
|
|
|
|
import org.apache.poi.ss.usermodel.Workbook; |
|
|
|
|
|
|
|
import org.apache.poi.ss.usermodel.WorkbookFactory; |
|
|
|
|
|
|
|
import org.junit.Assert; |
|
|
|
import org.junit.BeforeClass; |
|
|
|
import org.junit.BeforeClass; |
|
|
|
import org.junit.FixMethodOrder; |
|
|
|
import org.junit.FixMethodOrder; |
|
|
|
import org.junit.Test; |
|
|
|
import org.junit.Test; |
|
|
@ -40,20 +47,26 @@ public class StyleDataTest { |
|
|
|
|
|
|
|
|
|
|
|
private static File file07; |
|
|
|
private static File file07; |
|
|
|
private static File file03; |
|
|
|
private static File file03; |
|
|
|
|
|
|
|
private static File fileVerticalCellStyleStrategy07; |
|
|
|
|
|
|
|
private static File fileVerticalCellStyleStrategy207; |
|
|
|
|
|
|
|
private static File fileLoopMergeStrategy; |
|
|
|
|
|
|
|
|
|
|
|
@BeforeClass |
|
|
|
@BeforeClass |
|
|
|
public static void init() { |
|
|
|
public static void init() { |
|
|
|
file07 = TestFileUtil.createNewFile("style07.xlsx"); |
|
|
|
file07 = TestFileUtil.createNewFile("style07.xlsx"); |
|
|
|
file03 = TestFileUtil.createNewFile("style03.xls"); |
|
|
|
file03 = TestFileUtil.createNewFile("style03.xls"); |
|
|
|
|
|
|
|
fileVerticalCellStyleStrategy07 = TestFileUtil.createNewFile("verticalCellStyle.xlsx"); |
|
|
|
|
|
|
|
fileVerticalCellStyleStrategy207 = TestFileUtil.createNewFile("verticalCellStyle2.xlsx"); |
|
|
|
|
|
|
|
fileLoopMergeStrategy = TestFileUtil.createNewFile("loopMergeStrategy.xlsx"); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Test |
|
|
|
@Test |
|
|
|
public void t01ReadAndWrite07() { |
|
|
|
public void t01ReadAndWrite07() throws Exception { |
|
|
|
readAndWrite(file07); |
|
|
|
readAndWrite(file07); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Test |
|
|
|
@Test |
|
|
|
public void t02ReadAndWrite03() { |
|
|
|
public void t02ReadAndWrite03() throws Exception { |
|
|
|
readAndWrite(file03); |
|
|
|
readAndWrite(file03); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -113,9 +126,12 @@ public class StyleDataTest { |
|
|
|
return writeCellStyle; |
|
|
|
return writeCellStyle; |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
EasyExcel.write(file07, StyleData.class).registerWriteHandler(verticalCellStyleStrategy).sheet() |
|
|
|
EasyExcel.write(fileVerticalCellStyleStrategy07, StyleData.class).registerWriteHandler( |
|
|
|
|
|
|
|
verticalCellStyleStrategy).sheet() |
|
|
|
.doWrite(data()); |
|
|
|
.doWrite(data()); |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Test |
|
|
|
@Test |
|
|
|
public void t04AbstractVerticalCellStyleStrategy02() { |
|
|
|
public void t04AbstractVerticalCellStyleStrategy02() { |
|
|
|
final StyleProperty styleProperty = StyleProperty.build(StyleData.class.getAnnotation(HeadStyle.class)); |
|
|
|
final StyleProperty styleProperty = StyleProperty.build(StyleData.class.getAnnotation(HeadStyle.class)); |
|
|
@ -152,32 +168,36 @@ public class StyleDataTest { |
|
|
|
return writeCellStyle; |
|
|
|
return writeCellStyle; |
|
|
|
} |
|
|
|
} |
|
|
|
}; |
|
|
|
}; |
|
|
|
EasyExcel.write(file07, StyleData.class).registerWriteHandler(verticalCellStyleStrategy).sheet() |
|
|
|
EasyExcel.write(fileVerticalCellStyleStrategy207, StyleData.class).registerWriteHandler( |
|
|
|
|
|
|
|
verticalCellStyleStrategy).sheet() |
|
|
|
.doWrite(data()); |
|
|
|
.doWrite(data()); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Test |
|
|
|
@Test |
|
|
|
public void t05LoopMergeStrategy() { |
|
|
|
public void t05LoopMergeStrategy() { |
|
|
|
EasyExcel.write(file07, StyleData.class).sheet().registerWriteHandler(new LoopMergeStrategy(2, 1)) |
|
|
|
EasyExcel.write(fileLoopMergeStrategy, StyleData.class).sheet().registerWriteHandler( |
|
|
|
|
|
|
|
new LoopMergeStrategy(2, 1)) |
|
|
|
.doWrite(data10()); |
|
|
|
.doWrite(data10()); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private void readAndWrite(File file) { |
|
|
|
private void readAndWrite(File file) throws Exception { |
|
|
|
SimpleColumnWidthStyleStrategy simpleColumnWidthStyleStrategy = new SimpleColumnWidthStyleStrategy(50); |
|
|
|
SimpleColumnWidthStyleStrategy simpleColumnWidthStyleStrategy = new SimpleColumnWidthStyleStrategy(50); |
|
|
|
SimpleRowHeightStyleStrategy simpleRowHeightStyleStrategy = |
|
|
|
SimpleRowHeightStyleStrategy simpleRowHeightStyleStrategy = |
|
|
|
new SimpleRowHeightStyleStrategy((short)40, (short)50); |
|
|
|
new SimpleRowHeightStyleStrategy((short)40, (short)50); |
|
|
|
|
|
|
|
|
|
|
|
WriteCellStyle headWriteCellStyle = new WriteCellStyle(); |
|
|
|
WriteCellStyle headWriteCellStyle = new WriteCellStyle(); |
|
|
|
headWriteCellStyle.setFillForegroundColor(IndexedColors.RED.getIndex()); |
|
|
|
headWriteCellStyle.setFillForegroundColor(IndexedColors.YELLOW.getIndex()); |
|
|
|
WriteFont headWriteFont = new WriteFont(); |
|
|
|
WriteFont headWriteFont = new WriteFont(); |
|
|
|
headWriteFont.setFontHeightInPoints((short)20); |
|
|
|
headWriteFont.setFontHeightInPoints((short)20); |
|
|
|
|
|
|
|
headWriteFont.setColor(IndexedColors.DARK_YELLOW.getIndex()); |
|
|
|
headWriteCellStyle.setWriteFont(headWriteFont); |
|
|
|
headWriteCellStyle.setWriteFont(headWriteFont); |
|
|
|
WriteCellStyle contentWriteCellStyle = new WriteCellStyle(); |
|
|
|
WriteCellStyle contentWriteCellStyle = new WriteCellStyle(); |
|
|
|
contentWriteCellStyle.setFillPatternType(FillPatternType.SOLID_FOREGROUND); |
|
|
|
contentWriteCellStyle.setFillPatternType(FillPatternType.SOLID_FOREGROUND); |
|
|
|
contentWriteCellStyle.setFillForegroundColor(IndexedColors.GREEN.getIndex()); |
|
|
|
contentWriteCellStyle.setFillForegroundColor(IndexedColors.TEAL.getIndex()); |
|
|
|
WriteFont contentWriteFont = new WriteFont(); |
|
|
|
WriteFont contentWriteFont = new WriteFont(); |
|
|
|
contentWriteFont.setFontHeightInPoints((short)20); |
|
|
|
contentWriteFont.setFontHeightInPoints((short)30); |
|
|
|
headWriteCellStyle.setWriteFont(contentWriteFont); |
|
|
|
contentWriteFont.setColor(IndexedColors.DARK_TEAL.getIndex()); |
|
|
|
|
|
|
|
contentWriteCellStyle.setWriteFont(contentWriteFont); |
|
|
|
HorizontalCellStyleStrategy horizontalCellStyleStrategy = |
|
|
|
HorizontalCellStyleStrategy horizontalCellStyleStrategy = |
|
|
|
new HorizontalCellStyleStrategy(headWriteCellStyle, contentWriteCellStyle); |
|
|
|
new HorizontalCellStyleStrategy(headWriteCellStyle, contentWriteCellStyle); |
|
|
|
|
|
|
|
|
|
|
@ -186,6 +206,29 @@ public class StyleDataTest { |
|
|
|
.registerWriteHandler(simpleRowHeightStyleStrategy).registerWriteHandler(horizontalCellStyleStrategy) |
|
|
|
.registerWriteHandler(simpleRowHeightStyleStrategy).registerWriteHandler(horizontalCellStyleStrategy) |
|
|
|
.registerWriteHandler(onceAbsoluteMergeStrategy).sheet().doWrite(data()); |
|
|
|
.registerWriteHandler(onceAbsoluteMergeStrategy).sheet().doWrite(data()); |
|
|
|
EasyExcel.read(file, StyleData.class, new StyleDataListener()).sheet().doRead(); |
|
|
|
EasyExcel.read(file, StyleData.class, new StyleDataListener()).sheet().doRead(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Workbook workbook = WorkbookFactory.create(file); |
|
|
|
|
|
|
|
Sheet sheet = workbook.getSheetAt(0); |
|
|
|
|
|
|
|
Row row0 = sheet.getRow(0); |
|
|
|
|
|
|
|
Cell cell00 = row0.getCell(0); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {-1, -1, 0}, StyleTestUtils.getFillForegroundColor(cell00)); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {-128, -128, 0}, StyleTestUtils.getFontColor(cell00, workbook)); |
|
|
|
|
|
|
|
Assert.assertEquals(20, StyleTestUtils.getFontHeightInPoints(cell00, workbook)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Cell cell01 = row0.getCell(1); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {-1, -1, 0}, StyleTestUtils.getFillForegroundColor(cell01)); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {-128, -128, 0}, StyleTestUtils.getFontColor(cell01, workbook)); |
|
|
|
|
|
|
|
Assert.assertEquals(20, StyleTestUtils.getFontHeightInPoints(cell01, workbook)); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Row row1 = sheet.getRow(1); |
|
|
|
|
|
|
|
Cell cell10 = row1.getCell(0); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {0, -128, -128}, StyleTestUtils.getFillForegroundColor(cell10)); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {0, 51, 102}, StyleTestUtils.getFontColor(cell10, workbook)); |
|
|
|
|
|
|
|
Assert.assertEquals(30, StyleTestUtils.getFontHeightInPoints(cell10, workbook)); |
|
|
|
|
|
|
|
Cell cell11 = row1.getCell(1); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {0, -128, -128}, StyleTestUtils.getFillForegroundColor(cell11)); |
|
|
|
|
|
|
|
Assert.assertArrayEquals(new byte[] {0, 51, 102}, StyleTestUtils.getFontColor(cell11, workbook)); |
|
|
|
|
|
|
|
Assert.assertEquals(30, StyleTestUtils.getFontHeightInPoints(cell11, workbook)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private List<StyleData> data() { |
|
|
|
private List<StyleData> data() { |
|
|
|