溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java怎么實(shí)現(xiàn)讀取及生成Excel文件的方法

發(fā)布時(shí)間:2021-04-26 12:27:15 來(lái)源:億速云 閱讀:563 作者:小新 欄目:編程語(yǔ)言

這篇文章主要介紹Java怎么實(shí)現(xiàn)讀取及生成Excel文件的方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

常用的java框架有哪些

1.SpringMVC,Spring Web MVC是一種基于Java的實(shí)現(xiàn)了Web MVC設(shè)計(jì)模式的請(qǐng)求驅(qū)動(dòng)類型的輕量級(jí)Web框架。2.Shiro,Apache Shiro是Java的一個(gè)安全框架。3.Mybatis,MyBatis 是支持普通 SQL查詢,存儲(chǔ)過(guò)程和高級(jí)映射的優(yōu)秀持久層框架。4.Dubbo,Dubbo是一個(gè)分布式服務(wù)框架。5.Maven,Maven是個(gè)項(xiàng)目管理和構(gòu)建自動(dòng)化工具。6.RabbitMQ,RabbitMQ是用Erlang實(shí)現(xiàn)的一個(gè)高并發(fā)高可靠AMQP消息隊(duì)列服務(wù)器。7.Ehcache,EhCache 是一個(gè)純Java的進(jìn)程內(nèi)緩存框架。

一、讀取Excel文件

需要先下載poi-3.0.1-FINAL-20070705.jar(點(diǎn)擊此處本站下載poi-3.0.1-FINAL-20070705.jar。)

ExcelExamRead.java

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
public class ExcelExamRead {
/** 讀Excel文件內(nèi)容 */
public void showExcel(String excelName) {
File file = new File(excelName);
FileInputStream in = null;
try {
// 創(chuàng)建對(duì)Excel工作簿文件的引用
in = new FileInputStream(file);
HSSFWorkbook hwb = new HSSFWorkbook(in);
HSSFSheet sheet = hwb.getSheet("myFirstExcel");// 根據(jù)指定的名字來(lái)引用此Excel中的有效工作表
// 讀取Excel 工作表的數(shù)據(jù)
System.out.println("下面是Excel文件" + file.getAbsolutePath() + "的內(nèi)容:");
HSSFRow row = null;
HSSFCell cell = null;
int rowNum = 0; 
// 行標(biāo)
int colNum = 0; 
// 列標(biāo)
for (; rowNum < 9; rowNum++) {
// 獲取第rowNum行
row = sheet.getRow((short) rowNum);
for (colNum = 0; colNum < 5; colNum++) {
cell = row.getCell((short) colNum);// 根據(jù)當(dāng)前行的位置來(lái)創(chuàng)建一個(gè)單元格對(duì)象
System.out.print(cell.getStringCellValue() + "\t");// 獲取當(dāng)前單元格中的內(nèi)容
}
System.out.println(); // 換行
}
in.close();
} catch (Exception e) {
System.out
.println("讀取Excel文件" + file.getAbsolutePath() + "失?。?quot; + e);
} finally {
if (in != null) {
try {
in.close();
} catch (IOException e1) {
}
}
}
}
public static void main(String[] args) {
ExcelExamRead excel = new ExcelExamRead();
String excelName = "D:/ExcelExamRead.xls";
excel.showExcel(excelName);
}
}

二、生成Excel文件

ExcelExamWrite.java:

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.Region;
//創(chuàng)建Excel文件
public class ExcelExamWrite {
// 新建一個(gè)Excel文件,里面添加5行5列的內(nèi)容,另外添加一個(gè)合并2行5列的大單元格以及一個(gè)合并2行1列的5個(gè)合并單元格。
public void createExcel(String fileName) {
File file = new File(fileName);// 創(chuàng)建excel文件對(duì)象
FileOutputStream fOut = null;
try {
// 創(chuàng)建一個(gè)新的HSSFWorkbook對(duì)象
HSSFWorkbook workbook = new HSSFWorkbook();
// 創(chuàng)建一個(gè)Excel的工作表,可以指定工作表的名字
HSSFSheet sheet = workbook.createSheet("myFirstExcel");
// 創(chuàng)建字體,紅色、粗體
HSSFFont font = workbook.createFont();
font.setColor(HSSFFont.COLOR_RED);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
HSSFFont font1 = workbook.createFont();
// 創(chuàng)建字體,黑色、非粗體
font1.setColor(HSSFFont.COLOR_NORMAL);
font1.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);
// 創(chuàng)建單元格的格式,如居中、左對(duì)齊等
HSSFCellStyle cellStyle = workbook.createCellStyle();
cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平方向上居中對(duì)齊
// 垂直方向上居中對(duì)齊
cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
cellStyle.setFont(font); // 設(shè)置字體
HSSFCellStyle cellStyle1 = workbook.createCellStyle();
cellStyle1.setAlignment(HSSFCellStyle.ALIGN_LEFT);
cellStyle1.setFont(font1);
// 下面將建立一個(gè)4行3列的表。第一行為表頭。
int rowNum = 0;// 行標(biāo)
int colNum = 0;// 列標(biāo)
// 建立表頭信息
HSSFRow row = sheet.createRow((short) rowNum); // 在索引0的位置創(chuàng)建行
HSSFCell cell = null; // 單元格
for (colNum = 0; colNum < 5; colNum++) {
// 在當(dāng)前行的colNum列上創(chuàng)建單元格
cell = row.createCell((short) colNum);
// 定義單元格為字符類型,也可以指定為日期類型、數(shù)字類型
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
// 定義編碼方式,為了支持中文,這里使用了ENCODING_UTF_16
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
cell.setCellStyle(cellStyle); // 為單元格設(shè)置格式
cell.setCellValue("表頭-第" + (colNum + 1) + "列"); // 添加內(nèi)容至單元格
}
rowNum++;
for (; rowNum < 5; rowNum++) {
// 新建第rowNum行
row = sheet.createRow((short) rowNum);
for (colNum = 0; colNum < 5; colNum++) {
// 在當(dāng)前行的colNum位置創(chuàng)建單元格
cell = row.createCell((short) colNum);
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
cell.setCellStyle(cellStyle1);
cell.setCellValue("表體-第" + rowNum + "行第" + (colNum + 1)
+ "列");
}
}
// 合并單元格
// 先創(chuàng)建2行5列的單元格,然后將這些單元格合并為2個(gè)大單元格
rowNum = 5;
for (; rowNum < 9; rowNum++) {
row = sheet.createRow((short) rowNum);
for (colNum = 0; colNum < 5; colNum++) {
// 在當(dāng)前行的colNum位置創(chuàng)建單元格
cell = row.createCell((short) colNum);
}
}
// 建立第一個(gè)大單元格,高度為2,寬度為2
rowNum = 5;
colNum = 0;
Region region = new Region(rowNum, (short) colNum, (rowNum + 1),
(short) (colNum + 4));
sheet.addMergedRegion(region);
// 獲得第一個(gè)大單元格
cell = sheet.getRow(rowNum).getCell((short) colNum);
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
cell.setCellStyle(cellStyle);
cell.setCellValue("合并行單元格");
// 建立第二個(gè)大單元格,高度為2,寬度為3
rowNum = 7;
for (colNum = 0; colNum < 5; colNum++) {
region = new Region(rowNum, (short) colNum, (rowNum + 1),
(short) (colNum));
sheet.addMergedRegion(region);
// 獲得第二個(gè)大單元格
cell = sheet.getRow(rowNum).getCell((short) colNum);
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
cell.setCellStyle(cellStyle);
cell.setCellValue("合并列單元格");
}
// 新建一輸出文件流
fOut = new FileOutputStream(file);
// 將創(chuàng)建的內(nèi)容寫到指定的Excel文件中
workbook.write(fOut);
fOut.flush();
fOut.close();// 操作結(jié)束,關(guān)閉文件
System.out.println("Excel文件創(chuàng)建成功!\nExcel文件的存放路徑為:"
+ file.getAbsolutePath());
} catch (Exception e) {
System.out.println("Excel文件" + file.getAbsolutePath()
+ "創(chuàng)建失敗\n其原因?yàn)椋?quot; + e);
} finally {
if (fOut != null) {
try {
fOut.close();
} catch (IOException e1) {
}
}
}
}
public static void main(String[] args) throws Exception {
ExcelExamWrite excel = new ExcelExamWrite();
String fileName = "e:/ExcelExamWrite.xls";
excel.createExcel(fileName);
}
}

以上是“Java怎么實(shí)現(xiàn)讀取及生成Excel文件的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI