如何用java读取excel文件内容
答案:2 悬赏:80 手机版
解决时间 2021-04-13 14:35
- 提问者网友:送舟行
- 2021-04-13 09:57
如何用java读取excel文件内容
最佳答案
- 五星知识达人网友:煞尾
- 2021-04-13 10:58
读取excel一般使用开源工具包来读取的。因为office文件是经过处理的,用流读到的都是乱码。 你可以自己从百度“java 去读excel”找些资料,一堆一堆的。而且都封装好了,用起来也方便。 我这也有代码。如果你找到的代码都不可用,我再发给你。
全部回答
- 1楼网友:鸽屿
- 2021-04-13 11:37
本例使用java来读取excel的内容并展出出结果,代码如下:
复制代码 代码如下:
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 exceloperate {
public static void main(string[] args) throws exception {
file file = new file("exceldemo.xls");
string[][] result = getdata(file, 1);
int rowlength = result.length;
for(int i=0;i result = new arraylist();
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;
}
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);
}
}
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯