乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > 怎么用java<em>读取excel</em>文件

怎么用java<em>读取excel</em>文件

作者:乔山办公网日期:

返回目录:excel表格制作


java怎么读取上传的excel文件,解决办法:

  1. 添加jar文件,java导入导出Excel文件要引入jxl.jar包,最关键的是这套zdAPI是纯Java的,并不依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。

  2. jxl对Excel表格的认识,每个单元格的位置认为是由一个二维坐标(i,j)给定,其中i表示列,j表示行,并且从上到下递增,从左到右递增。

  3. 对于合并单元格的以最左,最上的单元格的坐标为准。如下图中t.xls,一班名单(0,0),陈茵(1,2),陈开先(1,6)。

4.java代码对t.xls的读取




简要介绍了开放源码项目Java Excel API,结合示例,详细叙述了有关Excel文件的读取方法,最后给出了一个例程及其运行结果.

在Java中读取Excel文件的内容

在这里,我使用的是一个叫Java Excel API的东西,类似的还有jakarta的POI,不过感觉那个

太复杂了点儿。而且jxl对中文的支持相当的好,至少我在用的过程中一点问题没出。

一、下载地址

http:///jexcelapi/

二、特性

可以读e69da5e6ba90e799bee5baa6e997aee7ad94362取Excel 95, 97, 2000文件

可以读或写Excel 97及其以后版本的的公式(不过我发现好像有bug)

生成Excel 97格式的电子表格

支持字体、数字和日期格式化

支持单元格的颜色和阴影

可以编辑现有的文件

三、读文件

//声明一下,记得后面要关闭哦。。

Workbook workbook = null;

try {

workbook = Workbook.getWorkbook(new File("d:\\temp\\TestRead.xls"));

} catch (Exception e) {

throw new Exception("file to import not found!");

}

Sheet sheet = workbook.getSheet(0);

Cell cell = null;

int columnCount=3;

int rowCount=sheet.getRows();

for (int i = 0; i<rowcount; p="" {

for (int j = 0; j<columncount; p="" {

//注意,这里的两个参数,第一个是表示列的,第二才表示行

cell=sheet.getCell(j, i);

//要根据单元格的类型分别做处理,否则格式化过的内容可能会不正确

if(cell.getType()==CellType.NUMBER){

System.out.print(((NumberCell)cell).getValue());

}

else if(cell.getType()==CellType.DATE){

System.out.print(((DateCell)cell).getDate());

}

else{

System.out.print(cell.getContents());

}

//System.out.print(cell.getContents());

System.out.print("\t");

}

System.out.print("\n");

}

//关闭它,否则会有内存泄露

workbook.close();



  下面是一个简单的读取例子,如果报“java.io.IOException: Invalid header signature; read 4503608217567241, expected -22262756”之类的异常请用Excel打开(如果能打的开的话)然后另存为一下。

http://www.jb51.net/article/43713.htm

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
public class Test0 {
 /**
  * @param args
  * @throws IOException
  * @throws FileNotFoundException
  */
 public static void main(String[] args) throws FileNotFoundException,
   IOException {
  File file = new File("C://test01.xls");// Excel文件路径
  String[][] result = getData(file, 1);
  int rowLength = result.length;
  for (int i = 0; i < rowLength; i++) {
   for (int j = 0; j < result[i].length; j++) {
    System.out.print(result[i][j] + "\t\t");
   }
   System.out.println();
  }
 }
 /**
  * 读取Excel的内容,第一维数组存储的是一行中格列的值,二维数组存储的是多少个行
  * 
  * @param file
  *            读取数据的源Excel
  * @param ignoreRows
  *            读取数据忽略的行数,比喻行头不需要读入 忽略的行数为1
  * @return 读出的Excel中数据的内容
  * @throws FileNotFoundException
  * @throws IOException
  */
 public static String[][] getData(File file, int ignoreRows)
   throws FileNotFoundException, IOException {
  List<String[]> result = new ArrayList<String[]>();
  int rowSize = 0;
  BufferedInputStream in = new BufferedInputStream(new FileInputStream(
    file));
  // 打开HSSFWorkbook
  POIFSFileSystem fs = new POIFSFileSystem(in);
  HSSFWorkbook wb = new HSSFWorkbook(fs);
  HSSFCell cell = null;
  for (int sheetIndex = 0; sheetIndex < wb.getNumberOfSheets(); sheetIndex++) {
   HSSFSheet st = wb.getSheetAt(sheetIndex);
   // 第一行为标题,不取
   for (int rowIndex = ignoreRows; rowIndex <= st.getLastRowNum(); rowIndex++) {
    HSSFRow row = st.getRow(rowIndex);
    if (row == null) {
     continue;
    }
    int tempRowSize = row.getLastCellNum() + 1;
    if (tempRowSize > rowSize) {
     rowSize = tempRowSize;
    }
    String[] values = new String[rowSize];
    Arrays.fill(values, "");
    boolean hasValue = false;
    for (short columnIndex = 0; columnIndex <= row.getLastCellNum(); columnIndex++) {
     String value = "";
     cell = row.getCell(columnIndex);
     if (cell != null) {
      // 注意:一定要设成这个,否则可能会出现乱码
      cell.setEncoding(HSSFCell.ENCODING_UTF_16);
      switch (cell.getCellType()) {
      case HSSFCell.CELL_TYPE_STRING:
       value = cell.getStringCellValue();
       break;
      case HSSFCell.CELL_TYPE_NUMERIC:
       if (HSSFDateUtil.isCellDateFormatted(cell)) {
        Date date = cell.getDateCellValue();
        if (date != null) {
         value = new SimpleDateFormat("yyyy-MM-dd")
           .format(date);
        } else {
         value = "";
        }
       } else {
        value = new DecimalFormat("0").format(cell
          .getNumericCellValue());
       }
       break;
      case HSSFCell.CELL_TYPE_FORMULA:
       // 导入时如果为公式生成的数据则无值
       if (!cell.getStringCellValue().equals("")) {
        value = cell.getStringCellValue();
       } else {
        value = cell.getNumericCellValue() + "";
       }
       break;
      case HSSFCell.CELL_TYPE_BLANK:
       break;
      case HSSFCell.CELL_TYPE_ERROR:
       value = "";
       break;
      case HSSFCell.CELL_TYPE_BOOLEAN:
       value = (cell.getBooleanCellValue() == true ? "Y"
         : "N");
       break;
      default:
       value = "";
      }
     }
     if (columnIndex == 0 && value.trim().equals("")) {
      break;
     }
     values[columnIndex] = rightTrim(value);
     hasValue = true;
    }
    if (hasValue) {
     result.add(values);
    }
   }
  }
  in.close();
  String[][] returnArray = new String[result.size()][rowSize];
  for (int i = 0; i < returnArray.length; i++) {
   returnArray[i] = (String[]) result.get(i);
  }
  return returnArray;
 }
 /**
  * 去掉字符串右边的空格e799bee5baa6e997aee7ad94e58685e5aeb9339
  * 
  * @param str
  *            要处理的字符串
  * @return 处理后的字符串
  */
 public static String rightTrim(String str) {
  if (str == null) {
   return "";
  }
  int length = str.length();
  for (int i = length - 1; i >= 0; i--) {
   if (str.charAt(i) != 0x20) {
    break;
   }
   length--;
  }
  return str.substring(0, length);
 }
}

相关阅读

  • 怎么用java<em>读取excel</em>文件

  • 乔山办公网excel表格制作
  • java怎么读取上传的excel文件,解决办法:添加jar文件,java导入导出Excel文件要引入jxl.jar包,最关键的是这套zdAPI是纯Java的,并不依赖Windows系统,即使运行在Linux下,它同样能够正确的处
  • Excel里的游戏怎么弄出来

  • 乔山办公网excel表格制作
  • ,《Excel 2000》隐藏的赛zd车游戏 以前微软的Office软件就常隐藏着有趣的小游戏,像之前的Word就曾藏有仿真飞行游 戏。 现在Excel 2000又有隐藏着一个3D赛车游戏唷,照着以下的方法做,你也
关键词不能为空
极力推荐

聚合标签

ppt怎么做_excel表格制作_office365_word文档_365办公网