Asp.net中把DataTable或DataGrid導出為Excel
Asp.net中把DataTable或DataGrid導出為Excel
當前編碼的一個項目中有把查詢結果(顯示在DataGrid)導出為excel的需求,嘗試了幾種方法,作為技巧拿來和大家分享。
內容:
服務器端實現DataGrid導出為excel
客戶端實現DataGrid導出為excel
服務器端實現DataTable導出為excel(終極解決方案)
服務器端實現DataGrid導出為excel
這是網上出現的最多的做法:

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

在需要導出的地方調用上面的方法就可以。不過這樣的實現有兩個問題:第一,datagrid中不能包含模板列;第二,只能夠導出當前顯示在datagrid的數據,無法在分頁的情況下導出全部的查詢結果。
如果大家分析一下Control.RenderControl的方法,就會發現RenderControl只是把控件的innerHTML導出來,既然如此,完全可以把導出操作放在客戶端來處理。
客戶端導出excel
2 * 將DataGrid導出為Excel文件
3 *
4 * @param strTitle 文件標題
5 * @param dgData 待導出的DataGrid
6 * @param iStartCol 起始列序號
7 * @param iEndCol 結束列序號
8 *
9 * 創建人: calvin
10 * 創建日期: 2005-10-08
11 * 修改人:
12 * 修改日期:
13 **/
14 function DataGrid2Excel(strTitle, dgData, iStartCol, iEndCol)
15 {
16 // 定義Excel Applicaiton Object
17 var appExcel = null;
18 // 當前激活的工作簿
19 var currentWork = null;
20 var currentSheet = null;
21
22 try
23 {
24 // 初始化application
25 appExcel = new ActiveXObject("Excel.Application");
26 appExcel.Visible = true;
27 }
28 catch(e)
29 {
30 window.alert("Please Install Excel First");
31
32 return;
33 }
34
35 // 獲取當前激活的工作部
36 currentWork = appExcel.Workbooks.Add();
37 currentSheet = currentWork.ActiveSheet;
38
39 // 填充excel內容
40 // 設置標題
41 currentSheet.Cells(1,1).Value = strTitle;
42 currentSheet.Cells(1,1).Value = dgData.innerText;
43 window.alert(dgData.innerHTML);
44
45 // 填充內容
46 for (var iRow = 0; iRow < dgData.rows.length - 1; iRow++)
47 {
48 // 顯示指定列的內容
49 for (var iCol = iStartCol; iCol <= iEndCol; iCol++)
50 {
51 currentSheet.Cells(iRow + 2, iCol + 1).Value =
52 dgData.rows[iRow].cells[iCol].innerText;
53 }
54 }
55 }
下面是調用的例子
2 * 導出dgData中0-3列的數據到excel文件中
3 **/
4 function ToExcel()
5 {
6 DataGrid2Excel("使用javascript導出excel的例子", document.getElementsById("dgData"), 0, 3);
7 }
這種方法的缺點是:
(1)了能夠在客戶端調用Excel.Application,需要把IE的安全級別設為“低”。
(2)與方法一相同,還是只能導出當前顯示在datagrid里面的數據,無法導出分頁的數據。
終極解決方案:將DataTable導出為excel
好,讓我們快點結束這篇無聊的post。一般來說,頁面上的datagrid是以查詢得到的一個DataTable為數據源的。那么為了把全部數據導入excel中,我們只要把DataTable數據源輸出為excel就可以了。

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

需要注意的是,導出excel之前要把datatable的列名更改為客戶要求的文字,就ok了。因為是從DataTable導出的,所以這種方法解決了分頁數據的問題,堪稱終極解決方案。