java讀取excel表格的方法
在使用java的時候,希望從excel中讀取到一些單元格的數(shù)據(jù),供大家參考,具體內(nèi)容如下
1.Java讀取的excel的api
這里用到了一個叫jxl的api如下:
<dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifactId>jxl</artifactId> <version>2.6.12</version> </dependency>
在java中需要去導(dǎo)入一些類去讀取excel
import jxl.Workbook; //java讀取excel表使用的類 import jxl.Cell; //java讀取表格里的單元格的類 import jxl.Sheet; //java讀取的工作鋪的類
首先:
創(chuàng)建一個File 去讀取文件(我以D盤redisInput文件下的GPSINFO.xls文件為例)
注意:不能夠讀取xlsx后綴的excel文件,否則會報錯: Unable to recognize OLE stream
File Inputfile = new File("D:\\redisInput\\GPSINFO.xls");
使用字符流去接File的數(shù)據(jù)
FileInputStream fileInputStream = new FileInputStream(Inputfile);
workbook去接fileInputStream
Workbook workbook = Workbook.getWorkbook(fileInputStream);
這樣讀取到了excel文件,但是需要去判斷是哪一個工作簿,要用到Sheet類
Sheet readfirst = workbook.getSheet(0);
如果getsheet(0)那么就是去訪問第一個工作簿里的數(shù)據(jù),然后可以在sheet類中看有多少有效行和有效列
int rows = readfirst.getRows();
int clomns = readfirst.getColumns();
System.out.println("row:" + rows);
System.out.println("clomns:" + clomns);
如果想看每個單元格的數(shù)據(jù)可以使用一個雙重循環(huán)去讀取每一個有效單元格里數(shù)據(jù)
for(int i =1;i<rows;i++) {
for(int j =1;i<rows;i++) {
Cell cell = readfirst.getCell(j,i); //j在前 i 在后是根據(jù)excel下標(biāo)來判斷的
String s = cell.getContents();
System.out.println("cell"+s);
}
這樣就把所有的有效單元格輸出了。
2.讀到的單元格進(jìn)行打印
但是我想讓它按照我想要的格式進(jìn)行輸出,比如 excel表中有sim卡 ,車牌號,終端號,我希望讓它能夠生成一個特有的格式讓我使用比如:
轉(zhuǎn)成-》
這種格式的數(shù)據(jù)
所以一個完整過程如下:
public class AnalysisExcel {
Workbook workbook = null;
File Inputfile = new File("D:\\redisInput\\GPSINFO.xls");
File outputfile =new File("D:\\redisInput\\GPSINFO.txt");
public void ToAnalysisExcel() {
// Unable to recognize OLE stream 不支持xlsx格式 支持xls格式
try {
FileInputStream fileInputStream = new FileInputStream(Inputfile);
workbook = Workbook.getWorkbook(fileInputStream);
FileOutputStream fileOutputStream = new FileOutputStream(outputfile);
BufferedOutputStream bw = new BufferedOutputStream(fileOutputStream); //輸出語句
Sheet readfirst = workbook.getSheet(0);
int rows = readfirst.getRows();
int clomns = readfirst.getColumns();
System.out.println("row:" + rows);
System.out.println("clomns:" + clomns);
for(int i =1;i<rows;i++) {
Cell[] cells = readfirst.getRow(i); //循環(huán)得到每一行的單元格對象
//根據(jù)每一個單元格對象的到里面的值
String brandNum= cells[0].getContents();
String deviceCode = cells[1].getContents();
String sim =cells[2].getContents();
System.out.println("rand:"+brandNum+",vehicleNum:"+deviceCode+",sim:"+sim);
//將得到的值放在一個我需要的格式的string對象中
String output = "\n"+sim+"\n" +
"{\n" +
" \"brandColor\": 500000,\n" +
" \"brandNumber\": \""+brandNum+"\",\n" +
" \"deviceCode\": \""+deviceCode+"\",\n" +
" \"simCard\": \""+sim+"\"\n" +
"}"+
"\n";
//write and flush到 我需要的文件中去,flush后才能成功
byte[] outputbyte = new String(output).getBytes();
bw.write(outputbyte);
bw.flush();
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (BiffException e) {
e.printStackTrace();
}
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java中BufferedReader和BufferedWriter使用方式
這篇文章主要介紹了Java中BufferedReader和BufferedWriter使用方式,F(xiàn)ileWriter?類從?OutputStreamWriter?類繼承而來,BufferedReader?類從字符輸入流中讀取文本并緩沖字符,以便有效地讀取字符,數(shù)組和行2022-06-06
解決使用@Component會導(dǎo)致spring.factories中的EnableAutoConfiguration無效
這篇文章主要介紹了解決使用@Component會導(dǎo)致spring.factories中的EnableAutoConfiguration無效問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-03-03
Eclipse配置tomcat發(fā)布路徑的問題wtpwebapps解決辦法
這篇文章主要介紹了Eclipse配置tomcat發(fā)布路徑的問題wtpwebapps解決辦法的相關(guān)資料,需要的朋友可以參考下2017-06-06
詳解Java如何實(shí)現(xiàn)與JS相同的Des加解密算法
這篇文章主要介紹了如何在Java中實(shí)現(xiàn)與JavaScript相同的DES(Data Encryption Standard)加解密算法,確保在兩個平臺之間可以無縫地傳遞加密信息,希望對大家有一定的幫助2025-04-04
Java如何獲取當(dāng)天零點(diǎn)和明天零點(diǎn)的時間和時間戳
這篇文章主要介紹了如何在Java中獲取當(dāng)天零點(diǎn)和明天零點(diǎn)的時間和時間戳,并提供了示例代碼,新手小白完全可以通過文中介紹的代碼實(shí)現(xiàn),需要的朋友可以參考下2025-03-03
關(guān)于二分法查找Java的實(shí)現(xiàn)及解析
這篇文章主要介紹了關(guān)于二分法查找Java的實(shí)現(xiàn)及解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

