All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.scudata.excel.ExcelVersionCompatibleUtil5 Maven / Gradle / Ivy

Go to download

SPL(Structured Process Language) A programming language specially for structured data computing.

There is a newer version: 20240823
Show newest version
package com.scudata.excel;

import java.awt.Color;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ooxml.POIXMLDocumentPart;
import org.apache.poi.openxml4j.opc.PackageRelationship;
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.CellValue;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.PictureData;
import org.apache.poi.ss.usermodel.RichTextString;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.VerticalAlignment;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.eventusermodel.XSSFReader;
import org.apache.poi.xssf.model.SharedStrings;
import org.apache.poi.xssf.model.SharedStringsTable;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.IndexedColorMap;
import org.apache.poi.xssf.usermodel.XSSFCellStyle;
import org.apache.poi.xssf.usermodel.XSSFClientAnchor;
import org.apache.poi.xssf.usermodel.XSSFColor;
import org.apache.poi.xssf.usermodel.XSSFDrawing;
import org.apache.poi.xssf.usermodel.XSSFPicture;
import org.apache.poi.xssf.usermodel.XSSFShape;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTMarker;

import com.scudata.common.ImageUtils;
import com.scudata.common.Logger;

public class ExcelVersionCompatibleUtil5 implements ExcelVersionCompatibleUtilInterface{
	
	private static final String ROW_COL_SEP = "_";
	
	public int getXSSFShape_EMU_PER_PIXEL() {
		return 9525;
	}
	
	public CellType getCellType(Cell c){
		return c.getCellType();
	}
	
	public short getHSSFColor_AUTOMATIC_Index() {
		return HSSFColor.HSSFColorPredefined.AUTOMATIC.getIndex();
	}

	public HorizontalAlignment getHSSFAlignmentEnum(HSSFCellStyle style){
		return style.getAlignment();
	}

	public VerticalAlignment getHSSFVerticalAlignmentEnum(HSSFCellStyle style) {
		return style.getVerticalAlignment();
	}

	public short getHSSFBorderLeft(HSSFCellStyle style){
		return style.getBorderLeft().getCode();
	}
	
	public short getHSSFBorderRight(HSSFCellStyle style){
		return style.getBorderRight().getCode();
	}
	
	public short getHSSFBorderTop(HSSFCellStyle style){
		return style.getBorderTop().getCode();
	}
	
	public short getHSSFBorderBottom(HSSFCellStyle style){
		return style.getBorderBottom().getCode();
	}
	
	public HorizontalAlignment getXSSFAlignmentEnum(XSSFCellStyle style){
		return style.getAlignment();
	}

	public VerticalAlignment getXSSFVerticalAlignmentEnum(XSSFCellStyle style){
		return style.getVerticalAlignment();
	}

	public short getXSSFBorderLeft(XSSFCellStyle style){
		return style.getBorderLeft().getCode();
	}
	
	public short getXSSFBorderRight(XSSFCellStyle style){
		return style.getBorderRight().getCode();
	}
	
	public short getXSSFBorderTop(XSSFCellStyle style){
		return style.getBorderTop().getCode();
	}
	
	public short getXSSFBorderBottom(XSSFCellStyle style){
		return style.getBorderBottom().getCode();
	}

	public boolean isCellTypeFomula(Cell cell) {
		return cell.getCellType().compareTo(CellType.FORMULA) == 0;
	}



	public int getColor(XSSFColor xc, Color defColor) {
		Color c = defColor;
		if (xc != null) {
			byte[] argb = xc.getARGB();
			if (argb != null) {
				// edited by hhw 2012.2.8???argb??û??aֵ?????????
				if (argb.length == 3) {
					byte[] tmp = new byte[4];
					tmp[0] = (byte) -1;
					tmp[1] = argb[0];
					tmp[2] = argb[1];
					tmp[3] = argb[2];
					argb = tmp;
				}
				c = new Color(byteToInt(argb[1]), byteToInt(argb[2]), byteToInt(argb[3]), byteToInt(argb[0]));
			}
		}
		return c.getRGB();
	}
	
	public int byteToInt(byte b) {
		if (b >= 0)
			return (int) b;
		return b + 256;
	}
	
	
	//use RqeditJar ooxml-schemas-1.3.jar
	public void addWaterRemarkToExcel(Workbook wbp, BufferedImage img, Sheet s) throws IOException{
		byte[] bytes = ImageUtils.writePNG( img );
		ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream(bytes.length);
		byteArrayOut.write(bytes);
		XSSFWorkbook xssfWb = null;
		if(wbp instanceof XSSFWorkbook) {
			xssfWb = ((XSSFWorkbook)wbp);
		}else if(wbp instanceof SXSSFWorkbook) {
			xssfWb = ((SXSSFWorkbook)wbp).getXSSFWorkbook();
		}
		Iterator poisheets = xssfWb.sheetIterator();
		Class XR = null;
		try {
			XR = Class.forName("org.apache.poi.xssf.usermodel.XSSFRelation");
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		}
		Field relationTypeEnumField = null;
		try {
			relationTypeEnumField = XR.getField("IMAGES");
		} catch (NoSuchFieldException e) {
			e.printStackTrace();
		} catch (SecurityException e) {
			e.printStackTrace();
		}
		while(poisheets.hasNext()) {
			XSSFSheet poisheet = (XSSFSheet) poisheets.next();//(XSSFSheet) s;
			int pictureIdx = wbp.addPicture( bytes, Workbook.PICTURE_TYPE_PNG); 
			if(poisheet.getCTWorksheet().isSetPicture()) continue;
			Class class1 = poisheet.getClass();
			//String rID = poisheet.addRelation(null, XSSFRelation.IMAGES, xssfWb.getAllPictures().get(pictureIdx)).getRelationship().getId();
			Method method = null;
			try {
				Class poiXMlRelationClass = Class.forName("org.apache.poi.ooxml.POIXMLRelation");
				Class pOIXMLDocumentPartClass = Class.forName("org.apache.poi.ooxml.POIXMLDocumentPart");
				method = class1.getMethod("addRelation", 
						new Class[] {
								String.class,
								poiXMlRelationClass,
								pOIXMLDocumentPartClass
								});
			} catch (NoSuchMethodException e) {
				e.printStackTrace();
			} catch (SecurityException e) {
				e.printStackTrace();
			} catch (ClassNotFoundException e) {
				e.printStackTrace();
			}
			PackageRelationship prs = null;
			try {
				Object relationPart = method.invoke(poisheet, null, relationTypeEnumField.get(XR), xssfWb.getAllPictures().get(pictureIdx));
				Class relationPartClass = relationPart.getClass();
				Method method2 = relationPartClass.getMethod("getRelationship");
				Object invoke = method2.invoke(relationPart);
				prs = (org.apache.poi.openxml4j.opc.PackageRelationship) invoke;
			} catch (IllegalAccessException e) {
				e.printStackTrace();
			} catch (IllegalArgumentException e) {
				e.printStackTrace();
			} catch (InvocationTargetException e) {
				e.printStackTrace();
			} catch (NoSuchMethodException e) {
				e.printStackTrace();
			} catch (SecurityException e) {
				e.printStackTrace();
			}
			String rID = prs.getId();
			poisheet.getCTWorksheet().addNewPicture().setId(rID); 
		}
	 }
	
	/** ??ñ߿???ʽ
	 * @param borderStyle ??Ǭ?????ж???ı߿???ʽ
	 * @param borderWidth ?߿????
	 * @return Excel?ı߿???ʽ
	 */
	public short getBorderStyle( byte borderStyle, float width ) {
		try {
			Class clazz = Class.forName("com.raqsoft.report.view.ExportExcelUtil2");
			Object o = clazz.newInstance();
			Method m = clazz.getMethod("getBorderStyle", Byte.class, Float.class);
			return (Short) m.invoke(o, borderStyle, width);
		}catch(Exception e) {
			return BorderStyle.THIN.getCode();	
		}
	}
	

	/**
	 * ??ñ߿???ʽ
	 * 
	 * @param borderStyle
	 *            ??Ǭ?????ж???ı߿???ʽ
	 * @param borderWidth
	 *            ?߿????
	 * @return Excel?ı߿???ʽ
	 */
	public short getISheetBorderStyle(byte borderStyle) {
		try {
			Class clazz = Class.forName("com.raqsoft.report.view.ExportExcelUtil2");
			Object o = clazz.newInstance();
			Method m = clazz.getMethod("getISheetBorderStyle",byte.class);
			return (Short) m.invoke(o, borderStyle);
		}catch(Exception e) {
			return BorderStyle.THIN.getCode();	
		}
	}
	
	public CellType getCellType(CellValue value){
		return value.getCellType();
	}

	public RichTextString getItemAt(SharedStrings sst, int idx){
		return sst.getItemAt(idx);
	}

	public void getSheetPictures(XSSFSheet sheet, Map graphMap) {
		List list = sheet.getRelations();
		for (POIXMLDocumentPart part : list) {
			if (part instanceof XSSFDrawing) {
				XSSFDrawing drawing = (XSSFDrawing) part;
				List shapes = drawing.getShapes();
				for (XSSFShape shape : shapes) {
					XSSFPicture picture = (XSSFPicture) shape;
					PictureData pdata = picture
							.getPictureData();
					if (pdata != null) {
						XSSFClientAnchor anchor = picture
								.getPreferredSize();
						CTMarker marker = anchor.getFrom();
						String key = marker.getRow()
								+ ROW_COL_SEP + marker.getCol();
						graphMap.put(key, pdata.getData());
						if (pdata.getPictureType() != Workbook.PICTURE_TYPE_PNG) {
							picture.resize();
						}
					}
				}
			}
		}
	}
	
	public int getFontIndex(Font font) {
		return font.getIndex();
	}
	
	public int getFontIndex(CellStyle style) {
		return style.getFontIndex();
	}
	
	public int getNumberOfFonts(Workbook wb) {
		return wb.getNumberOfFonts();
	}
	
	public int getNumberOfSheets(Workbook wb) {
		return wb.getNumberOfSheets();
	}

	public Font getFontAt(Workbook wb, Number index) {
		return wb.getFontAt(index.intValue());
	}

	public CellType getCachedFormulaResultType(Cell cell) {
		return cell.getCachedFormulaResultType();
	}

	public XSSFColor getXSSFColor(int color) {
		try {
			Constructor constructor = XSSFColor.class.getConstructor(java.awt.Color.class);
			return constructor.newInstance(new Color(color));
		}catch (Exception e) {
			return getXSSFColor525(color);
		}
	}
	
	public XSSFColor getXSSFColor525(int color) {
		Color color2 = new Color(color);
		try {
			Constructor constructor = XSSFColor.class.getConstructor(Color.class, IndexedColorMap.class);
			return constructor.newInstance(color2, null);
		}catch(Exception e) {
			Logger.debug(e);
			return null;
		}
	}

	@Override
	public SharedStrings readSharedStrings(XSSFReader xssfReader) {
		try {
			Method m = XSSFReader.class.getMethod("getSharedStringsTable", new Class[0]);
			Class returnType = m.getReturnType();
			if(returnType.getName().contains("SharedStringsTable")) {
				//poi5.0.0
				SharedStringsTable sst = (SharedStringsTable) m.invoke(xssfReader);
				return sst;
			} else {
				return readSharedStrings525(xssfReader);
			}
		}catch (Exception e) {
			Logger.debug(e);
			return null;
		}
	}
	
	public SharedStrings readSharedStrings525(XSSFReader xssfReader) throws NoSuchMethodException, SecurityException, IllegalAccessException, IllegalArgumentException, InvocationTargetException {
		Method m = XSSFReader.class.getMethod("getSharedStringsTable", new Class[0]);
		Class returnType = m.getReturnType();
		assert returnType.getName().endsWith("org.apache.poi.xssf.model.SharedStrings");
		
		//poi5.2.5
		SharedStrings sst = (SharedStrings) m.invoke(xssfReader);
		return sst;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy