java讀取excel表格的方法
在使用java的時(shí)候,希望從excel中讀取到一些單元格的數(shù)據(jù),供大家參考,具體內(nèi)容如下
1.Java讀取的excel的api
這里用到了一個(gè)叫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)建一個(gè)File 去讀取文件(我以D盤redisInput文件下的GPSINFO.xls文件為例)
注意:不能夠讀取xlsx后綴的excel文件,否則會報(bào)錯(cuò): 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文件,但是需要去判斷是哪一個(gè)工作簿,要用到Sheet類
Sheet readfirst = workbook.getSheet(0);
如果getsheet(0)那么就是去訪問第一個(gè)工作簿里的數(shù)據(jù),然后可以在sheet類中看有多少有效行和有效列
int rows = readfirst.getRows();
int clomns = readfirst.getColumns();
System.out.println("row:" + rows);
System.out.println("clomns:" + clomns);
如果想看每個(gè)單元格的數(shù)據(jù)可以使用一個(gè)雙重循環(huán)去讀取每一個(gè)有效單元格里數(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卡 ,車牌號,終端號,我希望讓它能夠生成一個(gè)特有的格式讓我使用比如:
轉(zhuǎn)成-》
這種格式的數(shù)據(jù)
所以一個(gè)完整過程如下:
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ù)每一個(gè)單元格對象的到里面的值
String brandNum= cells[0].getContents();
String deviceCode = cells[1].getContents();
String sim =cells[2].getContents();
System.out.println("rand:"+brandNum+",vehicleNum:"+deviceCode+",sim:"+sim);
//將得到的值放在一個(gè)我需要的格式的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)文章
SpringBoot中MyBatis-Plus 查詢時(shí)排除某些字段的操作方法
這篇文章主要介紹了SpringBoot中MyBatis-Plus 查詢時(shí)排除某些字段的操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08
IntelliJ IDEA修改內(nèi)存大小,使得idea運(yùn)行更流暢
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA修改內(nèi)存大小,使得idea運(yùn)行更流暢的文章,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-10-10
SpringBoot實(shí)現(xiàn)海量數(shù)據(jù)高效實(shí)時(shí)搜索功能
我們都知道隨著業(yè)務(wù)系統(tǒng)的發(fā)展和使用,數(shù)據(jù)庫存儲的業(yè)務(wù)數(shù)據(jù)量會越來越大,逐漸成為了業(yè)務(wù)系統(tǒng)的瓶頸,本文給大家介紹了Spring Boot業(yè)務(wù)系統(tǒng)如何實(shí)現(xiàn)海量數(shù)據(jù)高效實(shí)時(shí)搜索,文中有詳細(xì)的代碼示例,需要的朋友可以參考下2023-10-10
SpringBoot整合SpringSecurity和JWT的示例
這篇文章主要介紹了SpringBoot整合SpringSecurity和JWT的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Java BigDecimal解決double精度丟失的問題
我們在日常開發(fā)中, 有很多時(shí)候會遇到小數(shù)(double類型)精確計(jì)算,本文主要介紹了Java BigDecimal解決double精度丟失的問題,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11
Spring Boot中配置定時(shí)任務(wù)、線程池與多線程池執(zhí)行的方法
這篇文章主要給大家介紹了關(guān)于Spring Boot中配置定時(shí)任務(wù)、線程池與多線程池執(zhí)行的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Spring Boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09

