`
cd0281
  • 浏览: 119958 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

java读取excel(z)

    博客分类:
  • java
阅读更多
package download;

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 OperateExcel {
	/**
	  * @param args
	  */
	 /**
	  * 生成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.toString(), 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.toString(), 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 = { "学号", "姓名", "语文", "数学", "英语", "总分" };
	  OperateExcel jxl = new OperateExcel();
	  String filePath = "D:/test.xls";
	  jxl.createExcelFile(filePath, "成绩单", titles);
	  //jxl.readDataFromExcel(new File(filePath), 0);
	  //jxl.openExcel("C:/Program Files/Microsoft Office/OFFICE11/EXCEL.EXE",filePath);
	    
	 }

}
分享到:
评论

相关推荐

    读取Excel数据生成XML文件

    读取Excel数据生成XML文件 包括各种说明书 还要详细使用说明 http://zjava.org.ru/

    Excel POI读取封装(文件+示范代码)

    /** 读取Excel表格数据 */ public List, String&gt;&gt; readExcel(String excelName, Integer sheetIndex, String startPoint, String endPoint) throws Exception { FileInputStream inputStream = null; ...

    Java使用POI实现Excel报表的导入和导出

    利用开源组件POI3.0.2,用java语言实现了动态导出Excel文档,并且也实现了Excel文档的导入。有完整的例子,可直接使用。ExportExcel类为导出Excel报表通用类。 1.将源代码导入eclipse中 2.部署项目,启动tomcat...

    easyexcel工具类.7z

    阿里easyexcel读取Excel 的java 工具类

    Android国际化文本资源文件处理

    1,读取项目中的所有strings.xml文件并导出为excel得到excel1。 2,可以将同样结构的excel2中的内容同步到excel1。 3,将所有excel1中的内容以自行配置(StringsToExcel.java)的文件夹(如"values-ko-rKR", "values-ja...

    基于java开发的前后端分离的社会评估风险系统源码(前端Vue后端java)+数据库+项目使用说明.zip

    读取json文件,调用算法 # 调度方法完成了 算法文件位置 算法描述 数据库 本地文件 保存数据 当算法处理到预警值的时候,向后台发起服务调用,传递(指标相关数据)给后台进行调用,后台调用rabbitmq服务,然后广播...

    C#NPOI操作Excel手册

    NPOI,顾名思义,就是POI的.NET版本。那POI又是什么呢?POI是一套用Java写成的库,能够帮助开发者在没有...第五,完美支持Excel 2003格式(据说myxls无法正确读取xls模板,但NPOI可以),以后也许是所有Office 2003格式

    poi-ooxml-3.7-20101029.jar

    Java POI读取Office excel (2003,2007)及相关jar包 其中的poi-ooxml-3.7-20101029.jar

    poi-ooxml-schemas-3.7-20101029.jar

    Java POI读取Office excel (2003,2007)及相关jar包 其中必要的poi-ooxml-schemas-3.7-20101029.jar

    poi-contrib-3.6-20091214.jar

    Java POI读取Office excel (2003,2007)及相关jar包 其中相关的poi-contrib-3.6-20091214.jar

    poi-scratchpad-3.5-beta1.jar

    Java POI读取Office excel (2003,2007)及相关jar包 其中相关的poi-scratchpad-3.5-beta1.jar

    JSP实用技巧集合,jsp编程的一些小技巧总结

    7. jsp如判别一个字符在A到Z之间? 8. 得到一浮点数小数点后4位,如何写以函数截取为两位 9. 整型转字符? 10. 显示数据库的记录,点击哪个标题栏,就按照哪个标题排序 11. 制作两个按钮 12. 用什么sql语句将数据库中...

    jsp编程技巧集锦

    jsp如判别一个字符在A到Z之间? 8. 得到一浮点数小数点后4位,如何写以函数截取为两位 9. 整型转字符? 10. 显示数据库的记录,点击哪个标题栏,就按照哪个标题排序 11. 制作两个按钮 12. 用什么sql...

    网管教程 从入门到精通软件篇.txt

    /r 找到坏扇区并恢复可读取的信息。隐含着 /p 参数。  注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)中找到该文件,将试着在 Windows 安装 CD 中找到它。如果有多...

    易语言程序免安装版下载

    易语言5.1 相对于易语言5.0更新说明: ... 修改XML解析支持库,增加写出CDATA数据功能,解决解析XML时错误的丢弃换行和TAB字符的BUG,解决读取节点值时对CDATA数据进行转义处理的BUG。 20. 修改扩展界面支持库...

Global site tag (gtag.js) - Google Analytics