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.讀到的單元格進行打印
但是我想讓它按照我想要的格式進行輸出,比如 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)文章
SpringBoot中MyBatis-Plus 查詢時排除某些字段的操作方法
這篇文章主要介紹了SpringBoot中MyBatis-Plus 查詢時排除某些字段的操作方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08IntelliJ IDEA修改內(nèi)存大小,使得idea運行更流暢
今天小編就為大家分享一篇關(guān)于IntelliJ IDEA修改內(nèi)存大小,使得idea運行更流暢的文章,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10SpringBoot實現(xiàn)海量數(shù)據(jù)高效實時搜索功能
我們都知道隨著業(yè)務(wù)系統(tǒng)的發(fā)展和使用,數(shù)據(jù)庫存儲的業(yè)務(wù)數(shù)據(jù)量會越來越大,逐漸成為了業(yè)務(wù)系統(tǒng)的瓶頸,本文給大家介紹了Spring Boot業(yè)務(wù)系統(tǒng)如何實現(xiàn)海量數(shù)據(jù)高效實時搜索,文中有詳細的代碼示例,需要的朋友可以參考下2023-10-10SpringBoot整合SpringSecurity和JWT的示例
這篇文章主要介紹了SpringBoot整合SpringSecurity和JWT的示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06Java BigDecimal解決double精度丟失的問題
我們在日常開發(fā)中, 有很多時候會遇到小數(shù)(double類型)精確計算,本文主要介紹了Java BigDecimal解決double精度丟失的問題,具有一定的參考價值,感興趣的可以了解一下2023-11-11Spring Boot中配置定時任務(wù)、線程池與多線程池執(zhí)行的方法
這篇文章主要給大家介紹了關(guān)于Spring Boot中配置定時任務(wù)、線程池與多線程池執(zhí)行的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Spring Boot具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09