Java對(duì)xls文件進(jìn)行讀寫(xiě)操作示例代碼
前言
本文主要給大家介紹的是關(guān)于Java對(duì)xls文件進(jìn)行讀寫(xiě)操作的相關(guān)內(nèi)容,分享出來(lái)供大家參考學(xué)習(xí),下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹:
- win7_x64
- IDEA
Java讀寫(xiě)xls文件,使用庫(kù)jxl.jar
讀寫(xiě)xls文件,這里是在知道表格格式的前提下進(jìn)行操作的。
目前無(wú)法操作xlsx文件
準(zhǔn)備工作
將庫(kù)jxl.jar添加到工程依賴中
Java代碼示例
示例:從幾個(gè)文件中讀取數(shù)據(jù)并匯總到一個(gè)文件中
表格中的數(shù)據(jù)規(guī)定為:首行為標(biāo)題,以下是數(shù)據(jù)和名稱;例如
單位名 金額 單位1 948.34 單位2 4324 單位5 324
準(zhǔn)備好表格文件,放在指定目錄下
示例過(guò)程大致為:在指定目錄找到所有xls文件;遍歷所有文件,讀取出所有的單位名稱;將單位名稱排序;再遍歷一次所有文件,將每個(gè)文件中單位對(duì)應(yīng)的金額讀出并存儲(chǔ);最后寫(xiě)到輸出表格中。
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();
// 存儲(chǔ)單位名稱與金額對(duì)應(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)全部讀出來(lái),和名稱一次性全部寫(xiě)入
rwExcel.writeAllToResFile(resFilePath, nameRowHashMap, dataList);
// 補(bǔ)充標(biāo)題欄的標(biāo)題
if (null != sourceFiles) {
int col = 1; // 起始列的序號(hào)
for (File f : sourceFiles) {
String fileName = f.getName();
String name = fileName.substring(0, fileName.length() - 4);
rwExcel.updateContent(resFilePath, name, 0, col);
col++;
}
}
Java代碼
新建一個(gè)類RWExcel來(lái)操作xls文件。
public class RWExcel {
/**
* 存儲(chǔ)名稱
*/
private TreeSet<String> nameTreeSet = new TreeSet<>();
/**
* 名稱以及排列的下標(biāo)號(hà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開(kāi)始
*/
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 {
// 先寫(xiě)名稱
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);
// 遍歷這個(gè)map 將所有的數(shù)據(jù)對(duì)應(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)開(kāi)始
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é)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
使用java自帶des加密算法實(shí)現(xiàn)文件加密和字符串加密
這篇文章主要介紹了使用java自帶des加密算法實(shí)現(xiàn)文件加密和字符串加密的示例,需要的朋友可以參考下2014-03-03
Java?JDBC高封裝Util類的項(xiàng)目實(shí)踐
這篇文章主要介紹了Java?JDBC高封裝Util類的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
解決IDEA2020.1.2IDEA打不開(kāi)的問(wèn)題(最新分享)
由于idea安裝多了某個(gè)jar,點(diǎn)擊出現(xiàn)讀條后閃退情況,接下來(lái)通過(guò)本文給大家分享解決IDEA2020.1.2IDEA打不開(kāi)的問(wèn)題,非常不錯(cuò),具有一定的參考借鑒價(jià)值,感興趣的朋友跟隨小編一起看看吧2020-07-07
Java實(shí)現(xiàn)讀取Word模板文檔并替換內(nèi)容生成新文檔
在實(shí)際開(kāi)發(fā)中,經(jīng)常會(huì)遇到需要根據(jù) Word 模板生成特定文檔的需求,下面小編就來(lái)為大家介紹一下如何使用 Apache POI 庫(kù)來(lái)讀取 Word 模板文檔,然后替換其中的指定內(nèi)容最后生成新的文檔吧2025-02-02
使用spring動(dòng)態(tài)獲取接口的不同實(shí)現(xiàn)類
這篇文章主要介紹了使用spring動(dòng)態(tài)獲取接口的不同實(shí)現(xiàn)類,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02

