java mvc 導出excel_Java springMVC POI 導出 EXCEL

思路 :

將需要導出的數據存放在一個List中

創建一個EXCEL表 注意 XSSFWorkbook 只能操作2007以上的版本,XSSFWorkbook 只能操作2003一下的版本,所以需要的時候可以使用 Workbook創建對象處理兼容性

遍歷List 并將每條數據 寫入 EXCEL表中

具體代碼如下 :

html 頁面

導出

js 頁面

function download() {

$.messager.confirm('確認', '確認把該搜索結果導出Excel表格 ?', function(r) {

if (r) {

$.messager.progress({

title : '處理中',

msg : '請稍后',

});

$.messager.progress('close');

$.ajax({

url : 'download.html',//后臺方法名字

type : 'POST',

data : {

//傳入后臺的參數,從頁面獲取

},

success : function(data) {

//加載成功后的操作

}

});

}

});

}

后臺代碼

Model類 Student

public class Student {

private String name;

private int age;

private String address;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

public String getAddress() {

return address;

}

public void setAddress(String address) {

this.address = address;

}

}

處理邏輯,實現功能的類中代碼

@RequestMapping(value = "/download.html", method = RequestMethod.POST)

public void download(HttpServletRequest request,HttpServletResponse response) {

// TODO Auto-generated method stub

List list = new ArrayList();//Student是被導出數據的類型,一般是自己寫的Model類

XSSFWorkbook excelbook = new XSSFWorkbook(); //創建workBook

XSSFSheet excelSheet = excelbook.createSheet();//創建sheet表

XSSFRow excelRow = excelSheet.createRow(0);//創建行

XSSFCellStyle headerStyle = excelbook.createCellStyle();//設置 居中

headerStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);

//接下來是創建 列標題 ,cell的起始值是 0,可創建n個列標題

XSSFCell cell = excelRow.createCell(0);

cell.setCellStyle(headerStyle);//居中

cell.setCellValue("列標題 ");

//接下來遍歷List,并寫入EXCEL中

for(int i = 0; i < list.size(); i++){

//創建行,行號應從1開始,因為表頭行(列標題)占據了第0行

excelRow = excelSheet.createRow(i + 1);

Student t = list.get(i); // List 的起始值是0

//將該行每一列的數據寫入,可寫n列

cell = excelRow.createCell(0);

cell.setCellValue(t.getName());

}

try {

String filePath = "EXCEL表格導出路徑.xls";

writeExcel(response, excelbook, filePath, "文件名");//具體導出的方法

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

具體實現導出EXCEL的方法

//具體導出的方法

private static void writeExcel(HttpServletResponse response, Workbook work,

String filePath, String fileName) throws IOException {

OutputStream outputStream = new FileOutputStream(filePath);

try {

response.setContentType("application/ms-excel;charset=UTF-8");

response.setHeader("Content-Disposition", "attachment;filename="

.concat(String.valueOf(URLEncoder.encode(fileName + ".xls",

"UTF-8"))));

work.write(outputStream);

} catch (IOException e) {

System.out.println("輸出流錯誤");

e.printStackTrace();

} finally {

outputStream.close();

}

}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/533227.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/533227.shtml
英文地址,請注明出處:http://en.pswp.cn/news/533227.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 排序原理_簡單選擇排序算法原理及java實現(超詳細)

簡單選擇排序的原理簡單選擇排序的原理非常簡單&#xff0c;即在待排序的數列中尋找最大(或者最小)的一個數&#xff0c;與第 1 個元素進行交換&#xff0c;接著在剩余的待排序的數列中繼續找最大(最小)的一個數&#xff0c;與第 2 個元素交換。以此類推&#xff0c;一直到待排…

python對象點方法_python面向對象知識點疏理

面向對象技術簡介類:用來描述具有相同的屬性和方法的對象的集合。它定義了該集合中每個對象所共有的屬性和方法。對象是類的實例。class類變量&#xff1a;類變量在整個實例化的對象中是公用的。類變量定義在類中且在函數體之外。類變量通常不作為實例變量使用。數據成員&#…

ckeditor java 上傳_CKEditor粘貼圖片自動上傳到服務器(Java版)

環境&#xff1a;java,springmvc,ckeditor,tomcat,maven情況&#xff1a;在做項目的時候發現本地圖片粘貼到ckeditor中&#xff0c;img標簽的src中的值是“data:image/png;base64,”開頭的&#xff0c;后面會跟一串字符串&#xff0c;圖片越大字符串越長&#xff0c;這樣的圖片…

java 序列化聲明_顯式聲明默認Java類序列化方法的原因是什么?

我定期看到具有以下結構的Java類&#xff1a;class MyClass implements Serializable {private static final long serialVersionUID 1L;// ...private void writeObject(final java.io.ObjectOutputStream s) throws IOException {s.defaultWriteObject();}private void read…

java 百度poi_Android應用中使用百度地圖API之POI(三)

先看執行后的圖吧&#xff1a;POI(Point of Interest)。中文能夠翻譯為“興趣點”。在地理信息系統中。一個POI能夠是一棟房子、一個商鋪、一個郵筒、一個公交站等 具體&#xff1a;http://developer.baidu.com/map/sdkandev-4.htm主要應用 MKSearch 類&#xff1a;com.baidu.…

java 順序存儲鍵值對_java://Comparator、Comparable的用法(按照要求將map集合的鍵值對進行順序輸出)...

import java.util.*;public class Person implements Comparable//使Person的屬性具有比較性{private String name;private int age;public Person(String name,int age)//初始化構造函數{this.name name;this.age age;}public void set(String name,int age)//重新設置姓名和…

java日歷事件處理_日歷表的事件處理和管理(劉靜)

1 //添加gridview,顯示具體的日期2 SuppressLint("ResourceAsColor")3 private voidaddGridView() {4 LinearLayout.LayoutParams params newLinearLayout.LayoutParams(5 LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);6 //取得屏幕的寬度和高度7 WindowMa…

java第四次上機作業_第十java上機作業

第十java上機作業 第七章上級作業 7.1 public class Rectangle { double width1; double height1; String color“white“; public Rectangle(){} public Rectangle(double width,double height,String color) { this.widthwidth; this.heightheight; this.colorcolor; } publi…

java解析帶斜杠的參數_Java Spring MVC應用程序僅接受帶有斜杠的POST請求

war文件名是forms.war。 web.xml中的url模式為"/"控制器操作的RequestMapping為"/"如果遇到localhost&#xff1a;8080 /表單&#xff0c;則RequestMethod.GET操作正常工作如果針對localhost:8080/forms點擊發布數據&#xff0c;則不會觸發RequestMethod.P…

java文件編碼格式環境變量_Jenkins maven 構建亂碼,修改file.encoding系統變量編碼為UTF-8...

一切都是windows的控制臺默認編碼GBK問題情景&#xff1a;使用jenkins構建&#xff0c;console 輸出的中文亂碼。代碼編碼格式是utf-8&#xff0c;因為Jenkins會默認讀取當前系統的編碼格式&#xff0c;導致構建日志亂碼和selenium自動化測試輸入的中文亂碼。控制臺輸出亂碼摸索…

http multipart java_Http MultiPart請求

我正在嘗試使用httpClient庫上傳圖像(多部分/表單數據) . 我可以使用httpPost方法和byteArrayRequestEntity上傳圖像 . 以下是我使用的代碼&#xff1a;File file new File(imageFilePath);HttpClient client new HttpClient();PostMethod method new PostMethod("http…

java分布式會話redis_詳解springboot中redis的使用和分布式session共享問題

對于分布式使用NginxTomcat實現負載均衡&#xff0c;最常用的均衡算法有IP_Hash、輪訓、根據權重、隨機等。不管對于哪一種負載均衡算法&#xff0c;由于Nginx對不同的請求分發到某一個Tomcat&#xff0c;Tomcat在運行的時候分別是不同的容器里&#xff0c;因此會出現session不…

python3.8使用方法_python3.8新特性

python3.8新特性Python3.8穩定版已發布&#xff0c;官網發布了一篇介紹新特性的文章&#xff0c;在此記錄一下。新增賦值操作符:作用&#xff1a;把較大表達式中的某部分值賦給變量,因為看起來像海象的眼睛和牙齒&#xff0c;: 操作符有個特別的名字&#xff1a;海象操作符范例…

java責任鏈設計模式 訂單_Java責任鏈設計模式實例分析

本文實例講述了Java責任鏈設計模式。分享給大家供大家參考&#xff0c;具體如下&#xff1a;一 代碼abstract class AbstractHandler {private Handler Handler null;// 持有責任鏈中下一個責任處理者的引用public void setHandler( Handler handler ) {this.Handler handler…

java map去重復的數據_使用HashMap去重復數據.

因為HashMap是鍵值對形式&#xff0c;所以一個鍵只對應一個Value&#xff0c;利用這個原理&#xff0c;我們就可以根據某列重復數據做鍵對重復數據進行處理啦~首先先看看我要處理 的數據然后我最后想要的結果&#xff1a;需求&#xff1a;根據groupName每個分組信息只顯示一條數…

centos6.5 MySQL 服務器_啟用CentOS6.5 64位安裝時自帶的MySQL數據庫服務器

本人在虛擬機上又安裝了一臺linux機器&#xff0c;作為MySQL數據庫服務器用&#xff0c;在安裝時選擇了系統自帶的MySQL服務器端&#xff0c;以下是啟用步驟。首先開啟mysqld服務#service mysqld start進入/usr/bin目錄#cd /usr/bin設定mysql數據庫root用戶的密碼#mysqladmin -…

java xml date_W3C XML 模式時間數據類型與java Date進行轉換

W3C XML 模式時間數據格式:"2014-11-17T 09:40:25" 或者 “2014-11-17T 09:40:2508:00”要想把以上格式的時間轉換為能被java所使用個格式有以下3種辦法&#xff1a;(1)、jdk中有這么一個類XMLGregorianCalendar&#xff0c;使用XMLGregorianCalendar類中的toGreGreg…

PHP stomp 連接判斷,php實現通過stomp協議連接ActiveMQ操作示例

本文實例講述了php實現通過stomp協議連接ActiveMQ操作。分享給大家供大家參考&#xff0c;具體如下&#xff1a;前面介紹了php ActiveMQ的安裝與使用&#xff0c;這里再來講述一下php通過stomp協議連接ActiveMQ。一、安裝php的stomp擴展http://pecl.php.net/package/stomp如&am…

authinfo.php,【nginxphp】后臺權限認證方式

一、最常用的方法(代碼中限制)1、如何限制IPfunction get_new_ip(){if(getenv(HTTP_CLIENT_IP)) {$onlineip getenv(HTTP_CLIENT_IP);} elseif(getenv(HTTP_X_FORWARDED_FOR)) {$onlineip getenv(HTTP_X_FORWARDED_FOR);} elseif(getenv(REMOTE_ADDR)) {$onlineip getenv(RE…

php數組無限文類,php把無限級分類生成數組的類

你是否遇到需要把無限級分類循環出來&#xff0c;是不是很頭痛。比如&#xff0c;要循環出一個SELECT,或一個TABLE&#xff0c;要寫一大堆判斷。我的做法是生成數組&#xff0c;可以重復調用&#xff0c;直接循環數組就行了。為了方便&#xff0c;把它寫成了類&#xff1a;clas…