首页 > 其他 > 详细

Flex使用JXL导出Excel文档(包含设置时间、数字格式以及其他相关设置)

时间:2014-02-27 10:56:07      阅读:736      评论:0      收藏:0      [点我收藏+]

Flex端调用代码:

private function export():void
			{
				if (this.passVehicleList.length <= 0)
				{
					MessageDlg.confirm("数据为空,不能导出!", null);
					return;
				}
				parentname=parentname.replace(" ","");//去除名称中空格
				var startDate:Date = timeStart.appendTimevalue(dateStart.selectedDate);
				var stopDate:Date = timeStop.appendTimevalue(dateStop.selectedDate)
					
				var startTimes:String = MyStringUtil.datetimetoString(startDate);
				var stopTimes:String = MyStringUtil.datetimetoString(stopDate);
				var serarchstr:String = searchStr.text;
				inputParams.getParam("parentid").value = parentid;
				if(isOver){
					inputParams.getParam("isover").value = "over";
				}
				
				var contentTitle:String = startTimes+"至"+stopTimes+parentname;
				var reportName:String = parentname;
				var variables:URLVariables=new URLVariables();
				variables.parentid = parentid;
				variables.startTime = startTimes;
				variables.stopTime = stopTimes;
				variables.serarchstr = serarchstr;
				var coloumTitle:Array;
				if(!isOver){
					contentTitle=contentTitle+"日常报表";
					reportName=reportName+"日常报表";
					variables.isover = "";
					coloumTitle = new Array("名称","牌号","时间","类型","自重","载重","货重","备注");
				}else{
					contentTitle=contentTitle+"超载报表";
					reportName=reportName+"超载报表";
					variables.isover = "over";
					coloumTitle = new Array("名称","牌号","时间","车型","限重","载重","超载","车主","移动电话","备注");
				}
				variables.fileName=reportName+".xls";
				variables.contentTitle=contentTitle;
				variables.coloumTitle=coloumTitle;
				var u:URLRequest=new URLRequest(MyStringUtil.getUrlPath(Application.application.loaderInfo.url) + ‘/rest/ProjectAction.action‘);
				u.data=variables; //Pass the variables
				u.method=URLRequestMethod.POST; //Don‘t forget that we need to send as POST
				navigateToURL(u, "_self");
			}
使用variables传递所需要参数(包含Java端需要的查询条件、文件名、列标题)

Java服务端代码:

说明:需要jxl.jar包
import java.util.ArrayList;
import java.util.List;


import javax.servlet.http.HttpServletResponse;


import jxl.Workbook;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.VerticalAlignment;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.DateFormat;
import jxl.write.NumberFormat;
import jxl.write.NumberFormats;


import net.zdsoft.keel.action.ActionContext;
/*
     * Excel 导出使用 文件名  标题 行标题 导出内容
     */
    String fileName;//文件名
    String contentTitle;//内容标题
    String[] coloumTitle;//列标题
    /*******   查询条件       ********/
    String parentid;
    String startTime;
    String stopTime;
    String serarchstr;
    String isover;
    public String exportExcel() {
		// 以下开始输出到EXCEL
    	List<PassVehicle> contentList = new ArrayList<PassVehicle>();
    	InputParamList params = new InputParamList();
    	List<InputParam> paramList = new ArrayList<InputParam>();
    	if(parentid!=null&&!parentid.equals("")){
	    	InputParam param = new InputParam();
	    	param.setName("parentid");
	    	param.setValue(parentid);
	    	paramList.add(param);
    	}
    	if(startTime!=null&&!startTime.equals("")){
	    	InputParam param = new InputParam();
	    	param.setName("startTime");
	    	param.setValue(startTime);
	    	paramList.add(param);
    	}
    	if(stopTime!=null&&!stopTime.equals("")){
	    	InputParam param = new InputParam();
	    	param.setName("endTime");
	    	param.setValue(stopTime);
	    	paramList.add(param);
    	}
    	if(isover!=null&&!isover.equals("")){
	    	InputParam param = new InputParam();
	    	param.setName("isover");
	    	param.setValue(isover);
	    	paramList.add(param);
    	}
    	if(serarchstr!=null&&!serarchstr.equals("")){
    		InputParam param1 = new InputParam();
	    	param1.setName("type");
	    	param1.setValue("plateno");
	    	paramList.add(param1);
	    	InputParam param = new InputParam();
	    	param.setName("data");
	    	param.setValue(serarchstr);
	    	paramList.add(param);
    	}
    	params.setList(paramList);
    	contentList = SpringUtils.getPassVehicleService().queryBySQL(params);
		try {
			// 定义输出流,以便打开保存对话框
			ActionContext.getRequest().setCharacterEncoding("UTF-8");
			System.out.println("文件名:"+fileName);
			HttpServletResponse response = ActionContext.getResponse();
			OutputStream os = response.getOutputStream();// 取得输出流
			response.reset();// 清空输出流
			response.setCharacterEncoding("UTF-8");
			response.setHeader("pragma", "no-cache"); 
			response.setHeader("cache-control", "no-cache");
			response.setDateHeader("Expires", 0);
//			response.setContentType("application/vnd.ms-excel");
			response.setHeader("Content-disposition", "attachment; filename="
					+ new String(fileName.getBytes("GBK"), "ISO8859-1"));
			// 设定输出文件头
			response.setContentType("application/msexcel");// 定义输出类型
			// 设定输出文件头
			response.setContentType("application/msexcel");// 定义输出类型
			// 定义输出流,以便打开保存对话框_______________________end

			/** **********创建工作簿************ */
			WritableWorkbook workbook = Workbook.createWorkbook(os);

			/** **********创建工作表************ */

			WritableSheet sheet = workbook.createSheet("Sheet1", 0);
			
			/** **********设置行高列宽************ */
//			sheet.setRowView( 0 , 100 );
			sheet.setColumnView( 0 , 20 );
			sheet.setColumnView( 1 , 20 );
			sheet.setColumnView( 2 , 30 );
			sheet.setColumnView( 3 , 10 );
			sheet.setColumnView( 4 , 15 );
			sheet.setColumnView( 5 , 15 );
			sheet.setColumnView( 6 , 15 );
			sheet.setColumnView( 7 , 20 );
			if(isover!=null&&!isover.equals("")){
				sheet.setColumnView( 8 , 20 );
				sheet.setColumnView( 9 , 20 );
				sheet.mergeCells(0, 0, 9, 0);
			}else{
				sheet.mergeCells(0, 0, 7, 0);
			}
			/** **********设置纵横打印(默认为纵打)、打印纸***************** */
			jxl.SheetSettings sheetset = sheet.getSettings();
			sheetset.setProtected(false);

			/** ************设置单元格字体************** */
			WritableFont TitleFont = new WritableFont(WritableFont.createFont("宋体"), 16,
					WritableFont.BOLD);
			WritableFont HeadFont = new WritableFont(WritableFont.createFont("宋体"), 14,
					WritableFont.BOLD);
			WritableFont NormalFont = new WritableFont(WritableFont.createFont("宋体"), 12);
			
			/** ************设置时间、数字 格式************** */
			DateFormat df=new jxl.write.DateFormat("yyyy/MM/dd HH:mm:ss");
			NumberFormat nf = new jxl.write.NumberFormat("#.##");
			/** ************以下设置三种单元格样式,灵活备用************ */
			// 用于标题居中
			WritableCellFormat wcf_title = new WritableCellFormat(TitleFont);
			wcf_title.setBorder(Border.ALL, BorderLineStyle.THIN); // 线条
			wcf_title.setVerticalAlignment(VerticalAlignment.CENTRE); // 文字垂直对齐
			wcf_title.setAlignment(Alignment.CENTRE); // 文字水平对齐
			wcf_title.setWrap(false); // 文字是否换行
			// 用于标题头居中
			WritableCellFormat wcf_head = new WritableCellFormat(HeadFont);
			wcf_head.setBorder(Border.ALL, BorderLineStyle.THIN); // 线条
			wcf_head.setVerticalAlignment(VerticalAlignment.CENTRE); // 文字垂直对齐
			wcf_head.setAlignment(Alignment.CENTRE); // 文字水平对齐
			wcf_head.setWrap(false); // 文字是否换行
			// 用于正文居左
			WritableCellFormat wcf_left = new WritableCellFormat(NormalFont);
			wcf_left.setBorder(Border.ALL, BorderLineStyle.THIN); // 线条
			wcf_left.setVerticalAlignment(VerticalAlignment.CENTRE); // 文字垂直对齐
			wcf_left.setAlignment(Alignment.LEFT); // 文字水平对齐
			wcf_left.setWrap(false); // 文字是否换行
			// 用于时间单元格
			WritableCellFormat wcf_date = new WritableCellFormat(NormalFont,df);
			wcf_date.setBorder(Border.ALL, BorderLineStyle.THIN); // 线条
			wcf_date.setVerticalAlignment(VerticalAlignment.CENTRE); // 文字垂直对齐
			wcf_date.setAlignment(Alignment.LEFT); // 文字水平对齐
			wcf_date.setWrap(false); // 文字是否换行
			// 用于数字单元格
			WritableCellFormat wcf_num = new WritableCellFormat(NormalFont,NumberFormats.FLOAT);
			wcf_num.setBorder(Border.ALL, BorderLineStyle.THIN); // 线条
			wcf_num.setVerticalAlignment(VerticalAlignment.CENTRE); // 文字垂直对齐
			wcf_num.setAlignment(Alignment.LEFT); // 文字水平对齐
			wcf_num.setWrap(false); // 文字是否换行			
			
			/** ***************以下是EXCEL开头大标题********************* */
			if(contentTitle!=null&&!contentTitle.equals("")){
				sheet.addCell(new Label(0, 0, contentTitle, wcf_title));
			}
			/** ***************以下是EXCEL第一行列标题********************* */
			for (int i = 0; i < coloumTitle.length; i++) {
				sheet.addCell(new Label(i, 1, coloumTitle[i], wcf_head));
			}
			/** ***************以下是EXCEL正文数据********************* */
			int i = 2;
			if(contentList!=null){
				if(isover==null||isover.equals("")){
					for (PassVehicle obj : contentList) {
						sheet.addCell(new Label(0, i, obj.getName(), wcf_left));
						sheet.addCell(new Label(1, i, obj.getPlateNo(), wcf_left));
						sheet.addCell(new jxl.write.DateTime(2, i, obj.getPassTime(), wcf_date));
						sheet.addCell(new Label(3, i, obj.getVehicleType(), wcf_left));
						sheet.addCell(new jxl.write.Number(4, i, obj.getSelfWeight(), wcf_left));
						sheet.addCell(new jxl.write.Number(5, i, obj.getLoadWeight(), wcf_left));
						sheet.addCell(new jxl.write.Number(6, i, obj.getCommodityWeight(), wcf_num));
						sheet.addCell(new Label(7, i, obj.getRemarks(), wcf_left));
						i++;
					}
				}else{
					for (PassVehicle obj : contentList) {
						sheet.addCell(new Label(0, i, obj.getName(), wcf_left));
						sheet.addCell(new Label(1, i, obj.getPlateNo(), wcf_left));
						sheet.addCell(new jxl.write.DateTime(2, i, obj.getPassTime(), wcf_date));
						sheet.addCell(new Label(3, i, obj.getVehicleType(), wcf_left));
						sheet.addCell(new jxl.write.Number(4, i, obj.getLimitWeight(), wcf_num));
						sheet.addCell(new jxl.write.Number(5, i, obj.getLoadWeight(), wcf_num));
						sheet.addCell(new jxl.write.Number(6, i, obj.getOverWeight(), wcf_num));
						sheet.addCell(new Label(7, i, obj.getCarOwer(), wcf_left));
						sheet.addCell(new Label(8, i, obj.getMobile(), wcf_left));
						sheet.addCell(new Label(9, i, obj.getRemarks(), wcf_left));
						i++;
					}
				}
			}
			/** **********将以上缓存中的内容写到EXCEL文件中******** */
			workbook.write();
			/** *********关闭文件************* */
			workbook.close();

		} catch (Exception e) {
			System.out.println("系统提示:Excel文件导出失败,原因:"+ e.toString());
			e.printStackTrace();
		}
		return SUCCESS;
	}
相关资源下载地址:

其他jxl相关操作参考代码:
import java.io.File;  
import java.io.FileOutputStream;  
import java.io.OutputStream;  
import java.util.ArrayList;  
import java.util.Date;  
 
import jxl.Cell;  
import jxl.CellType;  
import jxl.Sheet;  
import jxl.Workbook;  
import jxl.WorkbookSettings;  
import jxl.format.Alignment;  
import jxl.format.Border;  
import jxl.format.BorderLineStyle;  
import jxl.format.Colour;  
import jxl.format.VerticalAlignment;  
import jxl.write.Formula;  
import jxl.write.Label;  
import jxl.write.NumberFormat;  
import jxl.write.WritableCellFeatures;  
import jxl.write.WritableCellFormat;  
import jxl.write.WritableFont;  
import jxl.write.WritableSheet;  
import jxl.write.WritableWorkbook;  
import jxl.write.WriteException;  
 
public class JExcelUtils {  
 
    /** 
     * 生成Excel文件 
     * @param path         文件路径 
     * @param sheetName    工作表名称 
     * @param dataTitles   数据标题 
     */ 
   public void createExcelFile(String path,String sheetName,String[] dataTitles){  
       WritableWorkbook workbook;  
       try{  
           OutputStream os=new FileOutputStream(path);   
           workbook=Workbook.createWorkbook(os);   
 
           WritableSheet sheet = workbook.createSheet(sheetName, 0); //添加第一个工作表  
           initialSheetSetting(sheet);  
             
           Label label;  
           for (int i=0; i<dataTitles.length; i++){  
               //Label(列号,行号,内容,风格)  
               label = new Label(i, 0, dataTitles[i],getTitleCellFormat());   
               sheet.addCell(label);   
           }  
 
           //插入一行  
           insertRowData(sheet,1,new String[]{"200201001","张三","100","60","100","260"},getDataCellFormat(CellType.STRING_FORMULA));  
             
           //一个一个插入行  
           label = new Label(0, 2,"200201002",getDataCellFormat(CellType.STRING_FORMULA));   
           sheet.addCell(label);  
             
           label = new Label(1, 2,"李四",getDataCellFormat(CellType.STRING_FORMULA));   
           sheet.addCell(label);  
             
           insertOneCellData(sheet,2,2,70.5,getDataCellFormat(CellType.NUMBER));  
           insertOneCellData(sheet,3,2,90.523,getDataCellFormat(CellType.NUMBER));  
           insertOneCellData(sheet,4,2,60.5,getDataCellFormat(CellType.NUMBER));  
 
           insertFormula(sheet,5,2,"C3+D3+E3",getDataCellFormat(CellType.NUMBER_FORMULA));  
             
           //插入日期  
           mergeCellsAndInsertData(sheet, 0, 3, 5, 3, new Date(), getDataCellFormat(CellType.DATE));  
             
           workbook.write();   
           workbook.close();  
       }catch(Exception e){  
           e.printStackTrace();  
       }  
   }  
     
   /** 
    * 初始化表格属性 
    * @param sheet 
    */ 
   public void initialSheetSetting(WritableSheet sheet){  
      try{  
           //sheet.getSettings().setProtected(true); //设置xls的保护,单元格为只读的  
           sheet.getSettings().setDefaultColumnWidth(10); //设置列的默认宽度  
           //sheet.setRowView(2,false);//行高自动扩展   
           //setRowView(int row, int height);--行高   
           //setColumnView(int  col,int width); --列宽  
           sheet.setColumnView(0,20);//设置第一列宽度  
      }catch(Exception e){  
          e.printStackTrace();  
      }  
   }  
     
   /** 
    * 插入公式 
    * @param sheet 
    * @param col 
    * @param row 
    * @param formula 
    * @param format 
    */ 
   public void insertFormula(WritableSheet sheet,Integer col,Integer row,String formula,WritableCellFormat format){  
       try{  
           Formula f = new Formula(col, row, formula, format);  
           sheet.addCell(f);  
       }catch(Exception e){  
           e.printStackTrace();  
       }  
   }  
     
   /** 
    * 插入一行数据 
    * @param sheet       工作表 
    * @param row         行号 
    * @param content     内容 
    * @param format      风格 
    */ 
   public void insertRowData(WritableSheet sheet,Integer row,String[] dataArr,WritableCellFormat format){  
       try{  
           Label label;  
           for(int i=0;i<dataArr.length;i++){  
               label = new Label(i,row,dataArr[i],format);  
               sheet.addCell(label);  
           }  
       }catch(Exception e){  
           e.printStackTrace();  
       }  
   }  
     
   /** 
    * 插入单元格数据 
    * @param sheet 
    * @param col 
    * @param row 
    * @param data 
    */ 
   public void insertOneCellData(WritableSheet sheet,Integer col,Integer row,Object data,WritableCellFormat format){  
       try{  
           if(data instanceof Double){  
               jxl.write.Number  labelNF = new jxl.write.Number(col,row,(Double)data,format);   
               sheet.addCell(labelNF);   
           }else if(data instanceof Boolean){  
               jxl.write.Boolean labelB = new jxl.write.Boolean(col,row,(Boolean)data,format);   
               sheet.addCell(labelB);   
           }else if(data instanceof Date){  
               jxl.write.DateTime labelDT = new jxl.write.DateTime(col,row,(Date)data,format);   
               sheet.addCell(labelDT);   
               setCellComments(labelDT, "这是个创建表的日期说明!");  
           }else{  
               Label label = new Label(col,row,data.toString(),format);  
               sheet.addCell(label);                 
           }  
       }catch(Exception e){  
           e.printStackTrace();  
       }  
 
  }  
     
   /** 
    * 合并单元格,并插入数据 
    * @param sheet 
    * @param col_start 
    * @param row_start 
    * @param col_end 
    * @param row_end 
    * @param data 
    * @param format 
    */ 
   public void mergeCellsAndInsertData(WritableSheet sheet,Integer col_start,Integer row_start,Integer col_end,Integer row_end,Object data, WritableCellFormat format){  
      try{  
          sheet.mergeCells(col_start,row_start,col_end,row_end);// 左上角到右下角  
          insertOneCellData(sheet, col_start, row_start, data, format);  
      }catch(Exception e){  
          e.printStackTrace();  
      }  
 
   }  
     
   /** 
    * 给单元格加注释 
    * @param label 
    * @param comments 
    */ 
   public void setCellComments(Object label,String comments){  
       WritableCellFeatures cellFeatures = new WritableCellFeatures();  
       cellFeatures.setComment(comments);  
       if(label instanceof jxl.write.Number){  
           jxl.write.Number num = (jxl.write.Number)label;  
           num.setCellFeatures(cellFeatures);  
       }else if(label instanceof jxl.write.Boolean){  
           jxl.write.Boolean bool = (jxl.write.Boolean)label;  
           bool.setCellFeatures(cellFeatures);  
       }else if(label instanceof jxl.write.DateTime){  
           jxl.write.DateTime dt = (jxl.write.DateTime)label;  
           dt.setCellFeatures(cellFeatures);  
       }else{  
           Label _label = (Label)label;  
           _label.setCellFeatures(cellFeatures);  
       }  
   }  
     
   /** 
   * 读取excel 
   * @param inputFile 
   * @param inputFileSheetIndex 
   * @throws Exception 
   */ 
   public ArrayList<String> readDataFromExcel(File inputFile, int inputFileSheetIndex){  
      ArrayList<String> list = new ArrayList<String>();  
      Workbook book = null;  
      Cell cell = null;  
      WorkbookSettings setting = new WorkbookSettings();   
      java.util.Locale locale = new java.util.Locale("zh","CN");   
      setting.setLocale(locale);  
      setting.setEncoding("ISO-8859-1");  
      try{  
          book = Workbook.getWorkbook(inputFile, setting);  
      }catch(Exception e){  
          e.printStackTrace();    
      }  
 
      Sheet sheet = book.getSheet(inputFileSheetIndex);  
      for (int rowIndex = 0; rowIndex < sheet.getRows(); rowIndex++) {//行  
       for (int colIndex = 0; colIndex < sheet.getColumns(); colIndex++) {//列  
           cell = sheet.getCell(colIndex, rowIndex);  
           //System.out.println(cell.getContents());  
           list.add(cell.getContents());  
       }  
      }  
      book.close();  
 
      return list;  
   }  
 
   /** 
    * 得到数据表头格式 
    * @return 
    */ 
   public WritableCellFormat getTitleCellFormat(){  
       WritableCellFormat wcf = null;  
       try {  
           //字体样式  
           WritableFont wf = new WritableFont(WritableFont.TIMES,12, WritableFont.NO_BOLD,false);//最后一个为是否italic  
           wf.setColour(Colour.RED);  
           wcf = new WritableCellFormat(wf);  
           //对齐方式  
           wcf.setAlignment(Alignment.CENTRE);  
           wcf.setVerticalAlignment(VerticalAlignment.CENTRE);  
           //边框  
           wcf.setBorder(Border.ALL,BorderLineStyle.THIN);  
             
           //背景色  
           wcf.setBackground(Colour.GREY_25_PERCENT);  
       } catch (WriteException e) {  
        e.printStackTrace();  
       }  
       return wcf;  
   }  
     
   /** 
    * 得到数据格式 
    * @return 
    */ 
   public WritableCellFormat getDataCellFormat(CellType type){  
       WritableCellFormat wcf = null;  
       try {  
           //字体样式  
           if(type == CellType.NUMBER || type == CellType.NUMBER_FORMULA){//数字  
              NumberFormat nf = new NumberFormat("#.00");  
              wcf = new WritableCellFormat(nf);   
           }else if(type == CellType.DATE || type == CellType.DATE_FORMULA){//日期  
               jxl.write.DateFormat df = new jxl.write.DateFormat("yyyy-MM-dd hh:mm:ss");   
               wcf = new jxl.write.WritableCellFormat(df);   
           }else{  
               WritableFont wf = new WritableFont(WritableFont.TIMES,10, WritableFont.NO_BOLD,false);//最后一个为是否italic  
               wcf = new WritableCellFormat(wf);  
           }  
           //对齐方式  
           wcf.setAlignment(Alignment.CENTRE);  
           wcf.setVerticalAlignment(VerticalAlignment.CENTRE);  
           //边框  
           wcf.setBorder(Border.LEFT,BorderLineStyle.THIN);  
           wcf.setBorder(Border.BOTTOM,BorderLineStyle.THIN);  
           wcf.setBorder(Border.RIGHT,BorderLineStyle.THIN);  
           //背景色  
           wcf.setBackground(Colour.WHITE);  
             
           wcf.setWrap(true);//自动换行  
             
       } catch (WriteException e) {  
        e.printStackTrace();  
       }  
       return wcf;  
   }  
     
   /** 
    * 打开文件看看 
    * @param exePath 
    * @param filePath 
    */ 
   public void openExcel(String exePath,String filePath){  
       Runtime r=Runtime.getRuntime();   
       String cmd[]={exePath,filePath};   
       try{   
           r.exec(cmd);   
       }catch(Exception e){  
           e.printStackTrace();  
       }  
   }  
     
   public static void main(String[] args){  
       String[] titles = {"学号","姓名","语文","数学","英语","总分"};   
       JExcelUtils jxl = new JExcelUtils();  
       String filePath = "E:/test.xls";  
       jxl.createExcelFile(filePath," 成绩单",titles);  
       jxl.readDataFromExcel(new File(filePath),0);  
       jxl.openExcel("C:/Program Files/Microsoft Office/OFFICE11/EXCEL.EXE",filePath);  
   }  
} 

import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import jxl.Cell;
import jxl.CellView;
import jxl.Sheet;
import jxl.SheetSettings;
import jxl.Workbook;
import jxl.format.Alignment;
import jxl.write.Label;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

/**
 * jxl操作excel的工具类.
 *
 */
public class JxlTool {
	public static int count = 1;
	//存储带有级别信息的内容到位置的映射关系.
	private static Map levelToLocation = new HashMap();
	
	public static void readExcel(String fileName) {
		Workbook wb = null;
		try {
			wb = Workbook.getWorkbook(new File(fileName));
			Sheet[] sheets = wb.getSheets();
			for(int i=0;i<sheets.length;i++){
				Sheet ii = sheets[i];
				System.out.println("第"+i+"个sheet的名字是"+ii.getName());
			}
		} catch (Exception e) {
			System.out.println("出现异常" + e);
			e.printStackTrace();
		} finally {
			wb.close();
		}
	}
	
	private static String allChar = "abcdefghijklmnopqrstuvwxyz";
	/**
	 * 从字符中得到列数.例如K-->10,A-->0,AA-->27
	 * @return
	 */
	public static int getNumFromExcelStr(String code)
 {
  int result = 0;
  code = code.toLowerCase();
  if(code.length()>1){
   char[] c = code.toCharArray();
   int len = c.length;
   for(int i=0;i<len;i++){
    if(i<len-1){
     result+=(allChar.indexOf(c[i])+1)*26; 
    }else{
     result+=allChar.indexOf(c[i])+1;
    }
   }
   result-=1;
  }
  else
   return allChar.indexOf(code);
  return result;
 }	
	/**
	 * 根据行号和列号得到所在的单元格.例如(3,4)-->"E4"
	 * @param vNum 纵坐标
	 * @param hNum 横坐标
	 * @return
	 */
	public static String getCellInfo(int hNum,int vNum){
		char[] cs = allChar.toCharArray();
		String hStr = "";
		if(vNum>25){
			hStr = String.valueOf(cs[vNum/26-1])+String.valueOf(cs[vNum%26-1]);
		}else{
			hStr = String.valueOf(cs[vNum]);
		}
		return (hStr+Integer.toString((hNum+1))).toUpperCase();
	}

	/**
	 * 得到一个字符串里面的字符.A12-->A
	 * @param oldStr
	 * @return
	 */
	public static String getCodeFromStr(String oldStr){
		return oldStr.replaceAll("\\d", "");
	}
	
	/**
	 * 得到一个字符串里面的字符.A12-->12
	 * @param oldStr
	 * @return
	 */
	public static int getNumFromStr(String oldStr){
		return Integer.parseInt(oldStr.replaceAll("[a-zA-Z]", ""))-1;
	}
	
	/**
	 * 读取指定excel中的指定sheet的某一块的数据....用于模板里面读取单元格.
	 * @param fileName
	 * @param sheetIndex
	 * @param startRow
	 * @param endRow
	 * @param startColumn
	 * @param endColumn
	 */
	public static List readExcel(String fileName, int sheetIndex, int startRow,
			int endRow, int startColumn, int endColumn) {
		Workbook wb = null;
		List allData = new ArrayList();
		Cell cell = null;
		try {
			wb = Workbook.getWorkbook(new File(fileName));
			Sheet sheet = wb.getSheet(sheetIndex);
			int rowCount = sheet.getRows();
			int columnCount = sheet.getColumns();
			for (int r = startRow; r < rowCount && r <= endRow; r++) {// 行
				for (int c = startColumn; c < columnCount && c <= endColumn; c++) {// 列
					cell = sheet.getCell(c, r);
					// System.out.println(cell.getContents());
					allData.add(cell.getContents());
				}
			}
		} catch (Exception e) {
			System.out.println("出现异常" + e);
			e.printStackTrace();
		} finally {
			wb.close();
		}
		return allData;
	}
	
	/**
	 * 读取指定excel中的指定sheet的某一块的数据....用于模板里面读取单元格.
	 * @param fileName
	 * @param sheetIndex
	 * @param startCell
	 * @param endCell
	 * @return
	 */
	public static List readExcel(String fileName, int sheetIndex,String startCell, String endCell) {
		int startRow = getNumFromStr(startCell);
		int endRow = getNumFromStr(endCell);
		int startColumn=getNumFromExcelStr(getCodeFromStr(startCell));
		int endColumn = getNumFromExcelStr(getCodeFromStr(endCell));
		return readExcel(fileName, sheetIndex, startRow, endRow, startColumn,
				endColumn);
	}
		
	/**
	 * 设置excel中的sheet页全部隐藏
	 * @param fileName
	 */
	public static void setAllHiddenSheet(String fileName) {
		Workbook wb = null;
		try {
			wb = Workbook.getWorkbook(new File(fileName));
			// 打开一个文件副本,并指定数据写回原文件.
			WritableWorkbook book = Workbook.createWorkbook(new File(fileName),
					wb);
			Sheet[] sheets = book.getSheets();
			for(int i=3;i<sheets.length;i++){
				Sheet ii = sheets[i];
				ii.getSettings().setHidden(true);
			}
			book.write();
			book.close();
		} catch (Exception e) {
			System.out.println("出现异常" + e);
			e.printStackTrace();
		} finally {
			wb.close();
			System.out.print(111);
		}
	} 

       /**
          * 从行号和列号,得到所在的位置字符串,例如:row=7,col=7--->i8
          */
        public  static String getcodefromRC(int row,int col){
		char[] cc = allChar.toCharArray();
		return String.valueOf(cc[col])+(++row);
	}
    
	/**
	 * 添加一个新的sheet到指定excel文件
	 * @param fileName
	 * @param sheetName sheet的name
	 */
	public static void addNewSheet(String fileName,String sheetName) {
		Workbook wb = null;
		try {
			wb = Workbook.getWorkbook(new File(fileName));
			// 打开一个文件副本,并指定数据写回原文件.
			WritableWorkbook book = Workbook.createWorkbook(new File(fileName),
					wb);
			// 创建一个新的sheet到第2页的位置			
			String[] sheetNames = wb.getSheetNames();
			for(int i=0;i<sheetNames.length;i++){
				if(sheetNames[i].equals(sheetName)){
					System.out.println("已经存在了,不用添加了." );
					return ;
				}
			}
			WritableSheet sheet = book.createSheet(sheetName, 1);
			sheet.addCell(new Label(0, 0, "新加的测试数据"));
			book.write();
			book.close();
		} catch (Exception e) {
			System.out.println("出现异常" + e);
			e.printStackTrace();
		} finally {
			wb.close();
		}
	} 

        /**
          * 得到单元格的double内容,不可以直接使用cell.getContents(),因为这个方法是直接打印单元格内容
,单元格内容可能隐藏了后面的小数点!!        
          */
         public static double getNumber(Cell cell){
             NumberCell numberCell = (NumberCell)cell; 
            double namberValue = numberCell.getValue(); 
             return   namberValue ;         
         }

         /**
	 * 如果是公式返回公式的内容,否则返回单元格字符串表面内容
	 * @param c
	 * @return
	 */
         public static String getForJmulaStr(Cell c) {
		String ans = "";
		try {
			System.out.println(c.getType());
			if (c.getType() == CellType.NUMBER_FORMULA
					|| c.getType() == CellType.STRING_FORMULA
					|| c.getType() == CellType.BOOLEAN_FORMULA
					|| c.getType() == CellType.DATE_FORMULA
					|| c.getType() == CellType.FORMULA_ERROR) {
				FormulaCell nfc = (FormulaCell) c;
				ans = nfc.getFormula();
				
			} else {
				ans = c.getContents();
			}
		} catch (FormulaException e) {
			return "出现异常" + e.getMessage();
		} 
		return ans;
	}

      //得到指定位置单元格的值(普通单元格,数字单元格,日期单元格)
       private String getValue(Sheet sheet,int row,int col){
    	Cell cell=sheet.getCell(col, row);   
    	CellType cellType=cell.getType();
		NumberCell numberCell = null;
		String cellValue = "";
        //得到单元格的值
        if (cellType == CellType.NUMBER) {
	      numberCell = (NumberCell) cell;
	      cellValue = String.valueOf(numberCell.getValue());
       } else if (cellType == CellType.DATE) {
				cellValue = df.format(((DateCell) cell).getDate());
	 } else if (cellType == CellType.NUMBER_FORMULA) { 
		 // 形如:=123.232+3423.12
		 // 或者 =B2+123.12
		 NumberFormulaCell numberFormulaCell = (NumberFormulaCell) cell;
		 cellValue = String.valueOf(numberFormulaCell.getValue());
	 } else {
		 cellValue = cell.getContents();
	 }       
       cellValue=cellValue.replace(" ", "");  
        return cellValue;
    }
}

bubuko.com,布布扣



Flex使用JXL导出Excel文档(包含设置时间、数字格式以及其他相关设置),布布扣,bubuko.com

Flex使用JXL导出Excel文档(包含设置时间、数字格式以及其他相关设置)

原文:http://blog.csdn.net/zju2004/article/details/19974015

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!