永发信息网

如何用java读取excel文件内容

答案:2  悬赏:80  手机版
解决时间 2021-04-13 14:35
如何用java读取excel文件内容
最佳答案
读取excel一般使用开源工具包来读取的。因为office文件是经过处理的,用流读到的都是乱码。 你可以自己从百度“java 去读excel”找些资料,一堆一堆的。而且都封装好了,用起来也方便。 我这也有代码。如果你找到的代码都不可用,我再发给你。
全部回答
本例使用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); } }
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
手机屏上图标有很多用不上 想卸载了 在哪里面
梅村除了街上有眼镜店,还有哪里
动力网城我想知道这个在什么地方
膝关节疼痛是哪方面造成的,以后还能好吗
国际电信联盟的英文简称是什么?
《凤在江湖》片头曲歌词
怎么用驱动精灵把我的XP系统换成WIN7的?
撞车后当事人说没事走了,过了5小时后打电话说
新易丰怎么去啊,有知道地址的么
开机主机响一声是什么状况
怎样可以控制爱哭的坏毛病?
下列说法中正确的是A.太空中宇航员能对话,说
愚公移山有合适的名言,与愚公移山意义相同的
PS3能播放哪种格式的视频啊?
家里刚装不满一年的吊灯,今天发现下方的一圈
推荐资讯
阅读理解Lookatthis.It'sabluebag.Itismy
情深的一句独白好听吗,刘德华《情深的一句》
太原哪里可以买到风信子 贵么
煲什么汤可以滋阴降火,滋阴降火是什么意思 .
把1g某物质放入9g水中充分搅拌后,所得溶液的
金刚菩提怎么辨别真假,金刚菩提怎么鉴别真假
苏州拙政园是不是在装修啊?门票多少?
前不久新会发生了一件不可思议的恐怖事件,哪
南安市公路巡警霞美中队在哪里啊,我有事要去
兰亭序真迹找到没?
新年活动标语,关于祝村民新年快乐的横幅标语
常州市劳动西路广化里116号怎么走
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?