Java對xls文件進(jìn)行讀寫操作示例代碼
前言
本文主要給大家介紹的是關(guān)于Java對xls文件進(jìn)行讀寫操作的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹:
- win7_x64
- IDEA
Java讀寫xls文件,使用庫jxl.jar
讀寫xls文件,這里是在知道表格格式的前提下進(jìn)行操作的。
目前無法操作xlsx文件
準(zhǔn)備工作
將庫jxl.jar添加到工程依賴中
Java代碼示例
示例:從幾個文件中讀取數(shù)據(jù)并匯總到一個文件中
表格中的數(shù)據(jù)規(guī)定為:首行為標(biāo)題,以下是數(shù)據(jù)和名稱;例如
單位名 金額 單位1 948.34 單位2 4324 單位5 324
準(zhǔn)備好表格文件,放在指定目錄下
示例過程大致為:在指定目錄找到所有xls文件;遍歷所有文件,讀取出所有的單位名稱;將單位名稱排序;再遍歷一次所有文件,將每個文件中單位對應(yīng)的金額讀出并存儲;最后寫到輸出表格中。
final String wsFileDir = "H:/OtherWorkDocs/ws"; // 原始數(shù)據(jù)存放的目錄 final String resFilePath = "H:/OtherWorkDocs/output/jan_feb_mar_sum.xls"; RWExcel rwExcel = new RWExcel(); // 操作xls的實(shí)例 // 獲取所有的名稱并排序 TreeSet<String> nameSet = rwExcel.getNameSet(wsFileDir); // 將名稱與下標(biāo)存入map中 HashMap<String, Integer> nameRowHashMap = rwExcel.getNameRowHashMap(nameSet); File wsDir = new File(wsFileDir); // 源文件目錄 File[] sourceFiles = wsDir.listFiles(); // 存儲單位名稱與金額對應(yīng)的數(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); // 補(bǔ)充標(biāo)題欄的標(biāo)題 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<>(); /** * 名稱以及排列的下標(biāo)號 */ 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 * 下標(biāo)從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ù)對應(yīng)填入 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下標(biāo)開始 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) + " , 當(dāng)前獲取到的所有單位數(shù) " + hashSet.size()); } /** * 從原始數(shù)據(jù)中讀取并匹配的存入結(jié)果文件中 */ private HashMap<String, Float> getSourceData(String source) { File sFile = new File(source); if (!sFile.exists()) { System.out.println("原始文件不存在 復(fù)制失敗!"); 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); } }
示例運(yùn)行結(jié)果
得到以下結(jié)果(示例)
單位名稱 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
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
一文帶你掌握J(rèn)ava?LinkedBlockingQueue
LinkedBlockingQueue?是一個可選有界阻塞隊(duì)列,這篇文章主要為大家詳細(xì)介紹了Java中LinkedBlockingQueue的實(shí)現(xiàn)原理與適用場景,感興趣的可以了解一下2023-04-04java中orElse和orElseGet方法區(qū)別小結(jié)
這篇文章主要給大家介紹了關(guān)于java中orElse和orElseGet方法區(qū)別的相關(guān)資料,兩者之間的區(qū)別細(xì)微,但是卻在某些場景下顯的很重要,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10SpringBoot Actuator未授權(quán)訪問漏洞的排查和解決方法
Spring Boot Actuator 是開發(fā)和管理生產(chǎn)級 Spring Boot 應(yīng)用程序的重要工具,它可以幫助你確保應(yīng)用程序的穩(wěn)定性和性能,本文給大家介紹了SpringBoot Actuator未授權(quán)訪問漏洞的排查和解決方法,需要的朋友可以參考下2024-05-05RabbitMQ實(shí)現(xiàn)Work Queue工作隊(duì)列的示例詳解
工作隊(duì)列(又稱任務(wù)隊(duì)列)的主要思想是避免立即執(zhí)行資源密集型任務(wù),而不得不等待它完成。本篇文章將記錄和分享RabbitMQ工作隊(duì)列相關(guān)的知識點(diǎn),希望對大家有所幫助2023-01-01Intellj?idea新建的java源文件夾不是藍(lán)色的圖文解決辦法
idea打開java項(xiàng)目后新建的模塊中,java文件夾需要變成藍(lán)色,這篇文章主要給大家介紹了關(guān)于Intellj?idea新建的java源文件夾不是藍(lán)色的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02