Java對xls文件進行讀寫操作示例代碼
前言
本文主要給大家介紹的是關于Java對xls文件進行讀寫操作的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹:
- win7_x64
- IDEA
Java讀寫xls文件,使用庫jxl.jar
讀寫xls文件,這里是在知道表格格式的前提下進行操作的。
目前無法操作xlsx文件
準備工作
將庫jxl.jar添加到工程依賴中
Java代碼示例
示例:從幾個文件中讀取數(shù)據(jù)并匯總到一個文件中
表格中的數(shù)據(jù)規(guī)定為:首行為標題,以下是數(shù)據(jù)和名稱;例如
單位名 金額 單位1 948.34 單位2 4324 單位5 324
準備好表格文件,放在指定目錄下
示例過程大致為:在指定目錄找到所有xls文件;遍歷所有文件,讀取出所有的單位名稱;將單位名稱排序;再遍歷一次所有文件,將每個文件中單位對應的金額讀出并存儲;最后寫到輸出表格中。
final String wsFileDir = "H:/OtherWorkDocs/ws"; // 原始數(shù)據(jù)存放的目錄
final String resFilePath = "H:/OtherWorkDocs/output/jan_feb_mar_sum.xls";
RWExcel rwExcel = new RWExcel(); // 操作xls的實例
// 獲取所有的名稱并排序
TreeSet<String> nameSet = rwExcel.getNameSet(wsFileDir);
// 將名稱與下標存入map中
HashMap<String, Integer> nameRowHashMap = rwExcel.getNameRowHashMap(nameSet);
File wsDir = new File(wsFileDir); // 源文件目錄
File[] sourceFiles = wsDir.listFiles();
// 存儲單位名稱與金額對應的數(shù)據(jù)
List<HashMap<String, Float>> dataList = new ArrayList<>(10);
if (sourceFiles != null) {
for (File sF : sourceFiles) {
// 裝載數(shù)據(jù)
dataList.add(rwExcel.getSourceData(sF.getAbsolutePath()));
}
}
// 原始數(shù)據(jù)已經(jīng)全部讀出來,和名稱一次性全部寫入
rwExcel.writeAllToResFile(resFilePath, nameRowHashMap, dataList);
// 補充標題欄的標題
if (null != sourceFiles) {
int col = 1; // 起始列的序號
for (File f : sourceFiles) {
String fileName = f.getName();
String name = fileName.substring(0, fileName.length() - 4);
rwExcel.updateContent(resFilePath, name, 0, col);
col++;
}
}
Java代碼
新建一個類RWExcel來操作xls文件。
public class RWExcel {
/**
* 存儲名稱
*/
private TreeSet<String> nameTreeSet = new TreeSet<>();
/**
* 名稱以及排列的下標號
*/
private HashMap<String, Integer> nameRowMap = new HashMap<>();
public TreeSet<String> getNameSet(String wsPath) {
try {
File wsDir = new File(wsPath);
if (wsDir.exists() && wsDir.isDirectory()) {
println("工作目錄存在");
File[] files = wsDir.listFiles();
if (files != null && files.length > 0) {
for (File cFile : files) {
getNamesFromFile(cFile, this.nameTreeSet);
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
this.nameTreeSet.comparator();
return this.nameTreeSet;
}
/**
* 將名稱Set排序后存入HashMap
* 下標從1開始
*/
public HashMap<String, Integer> getNameRowHashMap(TreeSet<String> nameSet) {
nameSet.comparator();
int index = 1;
for (String name : nameSet) {
this.nameRowMap.put(name, index);
index++;
}
return this.nameRowMap;
}
/**
* 所有數(shù)據(jù)存入表格
*/
public void writeAllToResFile(String resFilePath, Map<String, Integer> nameMap, List<HashMap<String, Float>> dataList) {
File resFile = new File(resFilePath);
if (!resFile.exists()) {
try {
resFile.createNewFile();
} catch (IOException e) {
e.printStackTrace();
}
}
if (resFile.exists()) {
try {
// 先寫名稱
WritableWorkbook wwb = Workbook.createWorkbook(resFile);
WritableSheet ws = wwb.createSheet("sum", 0);
Label label = new Label(0, 0, "單位名稱");
ws.addCell(label);
for (Map.Entry<String, Integer> entry : nameMap.entrySet()) {
Label nameLabel = new Label(0, entry.getValue(), entry.getKey());
ws.addCell(nameLabel);
for (int j = 0; j < dataList.size(); j++) {
Number zeroCell = new Number(j + 1, entry.getValue(), 0);
ws.addCell(zeroCell);
}
}
for (int dataColumn = 0; dataColumn < dataList.size(); dataColumn++) {
HashMap<String, Float> dataMap = dataList.get(dataColumn);
// 遍歷這個map 將所有的數(shù)據(jù)對應填入
for (Map.Entry<String, Float> dataEntry : dataMap.entrySet()) {
int row = nameRowMap.get(dataEntry.getKey());
Number numberCell = new Number(dataColumn + 1, row, dataEntry.getValue());
ws.addCell(numberCell);
}
}
wwb.write();
wwb.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
private void getNamesFromFile(File inputFile, TreeSet<String> hashSet) throws IOException, BiffException {
Workbook workbook;
InputStream is = new FileInputStream(inputFile);
workbook = Workbook.getWorkbook(is);
Sheet sheet0 = workbook.getSheet(0);
int columnSum = sheet0.getColumns(); // 總列數(shù)
int rsRows = sheet0.getRows(); // 總行數(shù)
// 從1下標開始
for (int i = 1; i < rsRows; i++) {
Cell cell = sheet0.getCell(0, i);
if (!isEmpty(cell.getContents())) {
hashSet.add(cell.getContents());
}
}
println("此文件行數(shù)減一 = " + (rsRows - 1) + " , 當前獲取到的所有單位數(shù) " + hashSet.size());
}
/**
* 從原始數(shù)據(jù)中讀取并匹配的存入結果文件中
*/
private HashMap<String, Float> getSourceData(String source) {
File sFile = new File(source);
if (!sFile.exists()) {
System.out.println("原始文件不存在 復制失敗!");
return null;
}
// 讀取源文件中的所有數(shù)據(jù) <單位名稱, 數(shù)值>
HashMap<String, Float> sourceHashMap = new HashMap<>();
try {
Workbook sourceWs = Workbook.getWorkbook(sFile);
Sheet sSheet0 = sourceWs.getSheet(0);
int sTotalRows = sSheet0.getRows(); // 總行數(shù)
for (int i = 1; i < sTotalRows; i++) {
Cell cellKey = sSheet0.getCell(0, i);
Cell cellValue = sSheet0.getCell(1, i);
if (!isEmpty(cellKey.getContents()) && !isEmpty(cellValue.getContents())) {
sourceHashMap.put(cellKey.getContents(), Float.valueOf(cellValue.getContents()));
}
}
println(source + " 讀取到的數(shù)據(jù)數(shù)量 = " + sourceHashMap.size());
} catch (Exception e) {
e.printStackTrace();
}
return sourceHashMap;
}
public void updateContent(String filePath, String input, int row, int column) {
File file = new File(filePath);
if (!file.exists()) {
System.out.println(filePath + " does not exist!");
return;
}
try {
Workbook sourceWb = Workbook.getWorkbook(file);
WritableWorkbook wwb = Workbook.createWorkbook(file, sourceWb);
WritableSheet wSheet0 = wwb.getSheet(0);
Label label = new Label(column, row, input);
wSheet0.addCell(label);
wwb.write();
wwb.close();
} catch (Exception e) {
e.printStackTrace();
}
}
public RWExcel() {
}
private static boolean isEmpty(String str) {
if (null == str) {
return true;
}
return str.isEmpty();
}
private static void println(String in) {
System.out.println(in);
}
}
示例運行結果
得到以下結果(示例)
單位名稱 1月總金額 2月總金額 3月總金額 單位1 0 59.29999924 948.3400269 單位10 0 0 494.2000122 單位11 0 0 11.19999981 單位12 0 0 1.25 單位15 49.36000061 0 0 單位2 0 0 4324 單位24 0 34 0 單位5 0 23123 324 單位6 0 161.2599945 0
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
一文帶你掌握Java?LinkedBlockingQueue
LinkedBlockingQueue?是一個可選有界阻塞隊列,這篇文章主要為大家詳細介紹了Java中LinkedBlockingQueue的實現(xiàn)原理與適用場景,感興趣的可以了解一下2023-04-04
java中orElse和orElseGet方法區(qū)別小結
這篇文章主要給大家介紹了關于java中orElse和orElseGet方法區(qū)別的相關資料,兩者之間的區(qū)別細微,但是卻在某些場景下顯的很重要,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-10-10
SpringBoot Actuator未授權訪問漏洞的排查和解決方法
Spring Boot Actuator 是開發(fā)和管理生產(chǎn)級 Spring Boot 應用程序的重要工具,它可以幫助你確保應用程序的穩(wěn)定性和性能,本文給大家介紹了SpringBoot Actuator未授權訪問漏洞的排查和解決方法,需要的朋友可以參考下2024-05-05
RabbitMQ實現(xiàn)Work Queue工作隊列的示例詳解
工作隊列(又稱任務隊列)的主要思想是避免立即執(zhí)行資源密集型任務,而不得不等待它完成。本篇文章將記錄和分享RabbitMQ工作隊列相關的知識點,希望對大家有所幫助2023-01-01
Intellj?idea新建的java源文件夾不是藍色的圖文解決辦法
idea打開java項目后新建的模塊中,java文件夾需要變成藍色,這篇文章主要給大家介紹了關于Intellj?idea新建的java源文件夾不是藍色的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下2024-02-02

