欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java導(dǎo)出Excel通用方法實(shí)例

 更新時(shí)間:2019年05月15日 10:33:59   作者:戒_小俊  
這篇文章主要介紹了java導(dǎo)出Excel方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

數(shù)據(jù)導(dǎo)出到Excel幾乎是所有客戶都會(huì)提出的一個(gè)需求。下面我就分享一下我的代碼。

首先需要引入的jar包:

然后就是正式代碼了。

package lcy._41_50;
 
import java.io.FileOutputStream;
import java.io.OutputStream;
import java.net.URLEncoder;
 
import javax.servlet.http.HttpServletResponse;
 
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.CellRangeAddress;
import org.apache.poi.hssf.util.HSSFColor;
 
@SuppressWarnings( { "deprecation" })
public class Test46 {
 
	public static void main(String[] args) throws Exception {
 
		String sheetName = "用車統(tǒng)計(jì)表單";
		String titleName = "用車申請(qǐng)數(shù)據(jù)統(tǒng)計(jì)表";
		String fileName = "用車申請(qǐng)統(tǒng)計(jì)表單";
		int columnNumber = 3;
		int[] columnWidth = { 10, 20, 30 };
		String[][] dataList = { { "001", "2015-01-01", "IT" },
				{ "002", "2015-01-02", "市場(chǎng)部" }, { "003", "2015-01-03", "測(cè)試" } };
		String[] columnName = { "單號(hào)", "申請(qǐng)時(shí)間", "申請(qǐng)部門" };
		new Test46().ExportNoResponse(sheetName, titleName, fileName,
				columnNumber, columnWidth, columnName, dataList);
	}
 
	public void ExportWithResponse(String sheetName, String titleName,
			String fileName, int columnNumber, int[] columnWidth,
			String[] columnName, String[][] dataList,
			HttpServletResponse response) throws Exception {
		if (columnNumber == columnWidth.length&& columnWidth.length == columnName.length) {
			// 第一步,創(chuàng)建一個(gè)webbook,對(duì)應(yīng)一個(gè)Excel文件
			HSSFWorkbook wb = new HSSFWorkbook();
			// 第二步,在webbook中添加一個(gè)sheet,對(duì)應(yīng)Excel文件中的sheet
			HSSFSheet sheet = wb.createSheet(sheetName);
			// sheet.setDefaultColumnWidth(15); //統(tǒng)一設(shè)置列寬
			for (int i = 0; i < columnNumber; i++) 
			{
				for (int j = 0; j <= i; j++) 
				{
					if (i == j) 
					{
						sheet.setColumnWidth(i, columnWidth[j] * 256); // 單獨(dú)設(shè)置每列的寬
					}
				}
			}
			// 創(chuàng)建第0行 也就是標(biāo)題
			HSSFRow row1 = sheet.createRow((int) 0);
			row1.setHeightInPoints(50);// 設(shè)備標(biāo)題的高度
			// 第三步創(chuàng)建標(biāo)題的單元格樣式style2以及字體樣式headerFont1
			HSSFCellStyle style2 = wb.createCellStyle();
			style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);
			style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
			style2.setFillForegroundColor(HSSFColor.LIGHT_TURQUOISE.index);
			style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
			HSSFFont headerFont1 = (HSSFFont) wb.createFont(); // 創(chuàng)建字體樣式
			headerFont1.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字體加粗
			headerFont1.setFontName("黑體"); // 設(shè)置字體類型
			headerFont1.setFontHeightInPoints((short) 15); // 設(shè)置字體大小
			style2.setFont(headerFont1); // 為標(biāo)題樣式設(shè)置字體樣式
 
			HSSFCell cell1 = row1.createCell(0);// 創(chuàng)建標(biāo)題第一列
			sheet.addMergedRegion(new CellRangeAddress(0, 0, 0,
					columnNumber - 1)); // 合并列標(biāo)題
			cell1.setCellValue(titleName); // 設(shè)置值標(biāo)題
			cell1.setCellStyle(style2); // 設(shè)置標(biāo)題樣式
 
			// 創(chuàng)建第1行 也就是表頭
			HSSFRow row = sheet.createRow((int) 1);
			row.setHeightInPoints(37);// 設(shè)置表頭高度
 
			// 第四步,創(chuàng)建表頭單元格樣式 以及表頭的字體樣式
			HSSFCellStyle style = wb.createCellStyle();
			style.setWrapText(true);// 設(shè)置自動(dòng)換行
			style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
			style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 創(chuàng)建一個(gè)居中格式
 
			style.setBottomBorderColor(HSSFColor.BLACK.index);
			style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
			style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
			style.setBorderRight(HSSFCellStyle.BORDER_THIN);
			style.setBorderTop(HSSFCellStyle.BORDER_THIN);
 
			HSSFFont headerFont = (HSSFFont) wb.createFont(); // 創(chuàng)建字體樣式
			headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字體加粗
			headerFont.setFontName("黑體"); // 設(shè)置字體類型
			headerFont.setFontHeightInPoints((short) 10); // 設(shè)置字體大小
			style.setFont(headerFont); // 為標(biāo)題樣式設(shè)置字體樣式
 
			// 第四.一步,創(chuàng)建表頭的列
			for (int i = 0; i < columnNumber; i++) 
			{
				HSSFCell cell = row.createCell(i);
				cell.setCellValue(columnName[i]);
				cell.setCellStyle(style);
			}
 
			// 第五步,創(chuàng)建單元格,并設(shè)置值
			for (int i = 0; i < dataList.length; i++) 
			{
				row = sheet.createRow((int) i + 2);
				// 為數(shù)據(jù)內(nèi)容設(shè)置特點(diǎn)新單元格樣式1 自動(dòng)換行 上下居中
				HSSFCellStyle zidonghuanhang = wb.createCellStyle();
				zidonghuanhang.setWrapText(true);// 設(shè)置自動(dòng)換行
				zidonghuanhang.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 創(chuàng)建一個(gè)居中格式
 
				// 設(shè)置邊框
				zidonghuanhang.setBottomBorderColor(HSSFColor.BLACK.index);
				zidonghuanhang.setBorderBottom(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang.setBorderLeft(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang.setBorderRight(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang.setBorderTop(HSSFCellStyle.BORDER_THIN);
 
				// 為數(shù)據(jù)內(nèi)容設(shè)置特點(diǎn)新單元格樣式2 自動(dòng)換行 上下居中左右也居中
				HSSFCellStyle zidonghuanhang2 = wb.createCellStyle();
				zidonghuanhang2.setWrapText(true);// 設(shè)置自動(dòng)換行
				zidonghuanhang2
						.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 創(chuàng)建一個(gè)上下居中格式
				zidonghuanhang2.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中
 
				// 設(shè)置邊框
				zidonghuanhang2.setBottomBorderColor(HSSFColor.BLACK.index);
				zidonghuanhang2.setBorderBottom(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang2.setBorderLeft(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang2.setBorderRight(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang2.setBorderTop(HSSFCellStyle.BORDER_THIN);
				HSSFCell datacell = null;
				for (int j = 0; j < columnNumber; j++) 
				{
					datacell = row.createCell(j);
					datacell.setCellValue(dataList[i][j]);
					datacell.setCellStyle(zidonghuanhang2);
				}
			}
 
			// 第六步,將文件存到瀏覽器設(shè)置的下載位置
			String filename = fileName + ".xls";
			response.setContentType("application/ms-excel;charset=UTF-8");
			response.setHeader("Content-Disposition", "attachment;filename="
					.concat(String.valueOf(URLEncoder.encode(filename, "UTF-8"))));
			OutputStream out = response.getOutputStream();
			try {
				wb.write(out);// 將數(shù)據(jù)寫出去
				String str = "導(dǎo)出" + fileName + "成功!";
				System.out.println(str);
			} catch (Exception e) {
				e.printStackTrace();
				String str1 = "導(dǎo)出" + fileName + "失?。?;
				System.out.println(str1);
			} finally {
				out.close();
			}
 
		} else {
			System.out.println("列數(shù)目長(zhǎng)度名稱三個(gè)數(shù)組長(zhǎng)度要一致");
		}
 
	}
 
	public void ExportNoResponse(String sheetName, String titleName,
			String fileName, int columnNumber, int[] columnWidth,
			String[] columnName, String[][] dataList) throws Exception {
		if (columnNumber == columnWidth.length&& columnWidth.length == columnName.length) {
			// 第一步,創(chuàng)建一個(gè)webbook,對(duì)應(yīng)一個(gè)Excel文件
			HSSFWorkbook wb = new HSSFWorkbook();
			// 第二步,在webbook中添加一個(gè)sheet,對(duì)應(yīng)Excel文件中的sheet
			HSSFSheet sheet = wb.createSheet(sheetName);
			// sheet.setDefaultColumnWidth(15); //統(tǒng)一設(shè)置列寬
			for (int i = 0; i < columnNumber; i++) 
			{
				for (int j = 0; j <= i; j++) 
				{
					if (i == j) 
					{
						sheet.setColumnWidth(i, columnWidth[j] * 256); // 單獨(dú)設(shè)置每列的寬
					}
				}
			}
			// 創(chuàng)建第0行 也就是標(biāo)題
			HSSFRow row1 = sheet.createRow((int) 0);
			row1.setHeightInPoints(50);// 設(shè)備標(biāo)題的高度
			// 第三步創(chuàng)建標(biāo)題的單元格樣式style2以及字體樣式headerFont1
			HSSFCellStyle style2 = wb.createCellStyle();
			style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);
			style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
			style2.setFillForegroundColor(HSSFColor.LIGHT_TURQUOISE.index);
			style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
			HSSFFont headerFont1 = (HSSFFont) wb.createFont(); // 創(chuàng)建字體樣式
			headerFont1.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字體加粗
			headerFont1.setFontName("黑體"); // 設(shè)置字體類型
			headerFont1.setFontHeightInPoints((short) 15); // 設(shè)置字體大小
			style2.setFont(headerFont1); // 為標(biāo)題樣式設(shè)置字體樣式
 
			HSSFCell cell1 = row1.createCell(0);// 創(chuàng)建標(biāo)題第一列
			sheet.addMergedRegion(new CellRangeAddress(0, 0, 0,
					columnNumber - 1)); // 合并第0到第17列
			cell1.setCellValue(titleName); // 設(shè)置值標(biāo)題
			cell1.setCellStyle(style2); // 設(shè)置標(biāo)題樣式
 
			// 創(chuàng)建第1行 也就是表頭
			HSSFRow row = sheet.createRow((int) 1);
			row.setHeightInPoints(37);// 設(shè)置表頭高度
 
			// 第四步,創(chuàng)建表頭單元格樣式 以及表頭的字體樣式
			HSSFCellStyle style = wb.createCellStyle();
			style.setWrapText(true);// 設(shè)置自動(dòng)換行
			style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
			style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 創(chuàng)建一個(gè)居中格式
 
			style.setBottomBorderColor(HSSFColor.BLACK.index);
			style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
			style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
			style.setBorderRight(HSSFCellStyle.BORDER_THIN);
			style.setBorderTop(HSSFCellStyle.BORDER_THIN);
 
			HSSFFont headerFont = (HSSFFont) wb.createFont(); // 創(chuàng)建字體樣式
			headerFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); // 字體加粗
			headerFont.setFontName("黑體"); // 設(shè)置字體類型
			headerFont.setFontHeightInPoints((short) 10); // 設(shè)置字體大小
			style.setFont(headerFont); // 為標(biāo)題樣式設(shè)置字體樣式
 
			// 第四.一步,創(chuàng)建表頭的列
			for (int i = 0; i < columnNumber; i++) 
			{
				HSSFCell cell = row.createCell(i);
				cell.setCellValue(columnName[i]);
				cell.setCellStyle(style);
			}
 
			// 第五步,創(chuàng)建單元格,并設(shè)置值
			for (int i = 0; i < dataList.length; i++) 
			{
				row = sheet.createRow((int) i + 2);
				// 為數(shù)據(jù)內(nèi)容設(shè)置特點(diǎn)新單元格樣式1 自動(dòng)換行 上下居中
				HSSFCellStyle zidonghuanhang = wb.createCellStyle();
				zidonghuanhang.setWrapText(true);// 設(shè)置自動(dòng)換行
				zidonghuanhang
						.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 創(chuàng)建一個(gè)居中格式
 
				// 設(shè)置邊框
				zidonghuanhang.setBottomBorderColor(HSSFColor.BLACK.index);
				zidonghuanhang.setBorderBottom(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang.setBorderLeft(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang.setBorderRight(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang.setBorderTop(HSSFCellStyle.BORDER_THIN);
 
				// 為數(shù)據(jù)內(nèi)容設(shè)置特點(diǎn)新單元格樣式2 自動(dòng)換行 上下居中左右也居中
				HSSFCellStyle zidonghuanhang2 = wb.createCellStyle();
				zidonghuanhang2.setWrapText(true);// 設(shè)置自動(dòng)換行
				zidonghuanhang2
						.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 創(chuàng)建一個(gè)上下居中格式
				zidonghuanhang2.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中
 
				// 設(shè)置邊框
				zidonghuanhang2.setBottomBorderColor(HSSFColor.BLACK.index);
				zidonghuanhang2.setBorderBottom(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang2.setBorderLeft(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang2.setBorderRight(HSSFCellStyle.BORDER_THIN);
				zidonghuanhang2.setBorderTop(HSSFCellStyle.BORDER_THIN);
				HSSFCell datacell = null;
				for (int j = 0; j < columnNumber; j++) 
				{
					datacell = row.createCell(j);
					datacell.setCellValue(dataList[i][j]);
					datacell.setCellStyle(zidonghuanhang2);
				}
			}
 
			// 第六步,將文件存到指定位置
			try {
				FileOutputStream fout = new FileOutputStream("D:students.xls");
				wb.write(fout);
				String str = "導(dǎo)出" + fileName + "成功!";
				System.out.println(str);
				fout.close();
			} catch (Exception e) {
				e.printStackTrace();
				String str1 = "導(dǎo)出" + fileName + "失??!";
				System.out.println(str1);
			}
		} else {
			System.out.println("列數(shù)目長(zhǎng)度名稱三個(gè)數(shù)組長(zhǎng)度要一致");
		}
 
	}
 
}

為了本地測(cè)試效果,單獨(dú)寫了一個(gè)無response參數(shù)的ExportNoResponse方法,直接將文件保存到指定目錄D盤。

兩個(gè)方法的不同就在于第六步中,有response參數(shù)的方法可以將文件存到瀏覽器設(shè)置的下載位置。

下面是導(dǎo)出效果截圖:

以上所述是小編給大家介紹的java導(dǎo)出Excel方法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Java8中 LocalDate和java.sql.Date的相互轉(zhuǎn)換操作

    Java8中 LocalDate和java.sql.Date的相互轉(zhuǎn)換操作

    這篇文章主要介紹了Java8中 LocalDate和java.sql.Date的相互轉(zhuǎn)換操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Springboot集成Camunda使用Mysql介紹

    Springboot集成Camunda使用Mysql介紹

    大家好,本篇文章主要講的是Springboot集成Camunda使用Mysql介紹,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • java 實(shí)現(xiàn)web項(xiàng)目啟動(dòng)加載properties屬性文件

    java 實(shí)現(xiàn)web項(xiàng)目啟動(dòng)加載properties屬性文件

    這篇文章主要介紹了java 實(shí)現(xiàn)web項(xiàng)目啟動(dòng)加載properties屬性文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java多線程編程綜合案例詳解

    Java多線程編程綜合案例詳解

    這篇文章將通過三個(gè)案例帶大家了解一下Java中的多線程編程,文中的示例代碼介紹詳細(xì),對(duì)我們的學(xué)習(xí)或工作有一定的價(jià)值,感興趣的小伙伴可以了解一下
    2022-07-07
  • 如何調(diào)用chatGPT實(shí)現(xiàn)代碼機(jī)器人

    如何調(diào)用chatGPT實(shí)現(xiàn)代碼機(jī)器人

    最近c(diǎn)hatGPT也是非常的火爆,相信大家都看到了,現(xiàn)在提供一種Java調(diào)用chatGPT的方法,我們主要通過兩個(gè)工具來實(shí)現(xiàn),一就是httpclient,二就是hutool,你覺得那種好理解你就用那種即可,今天通過本文給大家分享調(diào)用chatGPT實(shí)現(xiàn)代碼機(jī)器人,感興趣的朋友一起看看吧
    2022-12-12
  • 關(guān)于maven打包出錯(cuò)的解決方案

    關(guān)于maven打包出錯(cuò)的解決方案

    這篇文章主要介紹了關(guān)于maven打包出錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Java解決代碼重復(fù)的三個(gè)絕招分享

    Java解決代碼重復(fù)的三個(gè)絕招分享

    本文將從業(yè)務(wù)代碼中最常見的三個(gè)需求展開,聊聊如何使用?Java?中的一些高級(jí)特性、設(shè)計(jì)模式,以及一些工具消除重復(fù)代碼,才能既優(yōu)雅又高端
    2022-07-07
  • JavaCV實(shí)現(xiàn)圖片中人臉檢測(cè)的示例代碼

    JavaCV實(shí)現(xiàn)圖片中人臉檢測(cè)的示例代碼

    這篇文章主要介紹了如何利用JavaCV實(shí)現(xiàn)圖片中人臉檢測(cè)的功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的可以了解一下
    2022-11-11
  • shiro之INI配置詳解

    shiro之INI配置詳解

    這篇文章主要為大家詳細(xì)介紹了shiro之INI配置的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • Spring DevTools的介紹

    Spring DevTools的介紹

    今天小編就為大家分享一篇關(guān)于Spring DevTools的介紹,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-12-12

最新評(píng)論