asp.net中導出excel數據的方法匯總_.Net教程
推薦:Asp.Net 上傳圖片并生成高清晰縮略圖不是很復雜,大概寫一下。目的只在于實現,未仔細按照標準什么的來寫。其中參考了網上已經存在的代碼。 using System.Drawing; 頁面,如圖: 點擊提交按鈕: 整個實現的過程如下面的圖: 瀏覽頁面,選擇圖片: 點擊提交后,圖片以及縮略圖都已經生成到了目標文件夾里面
1、由dataset生成
2、由datagrid生成
3、這個用dataview
導入、導出EXCEL中的一些問題匯總
一、在項目中的添加引用:
右擊項目資源管理器的引用-->添加引用-->選擇.NET選項卡-->選擇Microsoft.Office.Interop.Excel-->確定(如下圖);
在選擇時注意一下.NET組件的版本號,圖是的12.0.0.0是Office2007的版本:
二、在項目中使用Microsoft.Office.Interop.Excel:
如果想使用Microsoft.Office.Interop.Excel,首先需要在項目中引用命名空間:
using Microsoft.Office.Interop.Excel;
三、建立Excel.Application相關對象
//建立Application對象
Microsoft.Office.Interop.Excel.Application myExcel = new Application();
//建立Workbooks對象
Workbooks myBooks = myExcel.Application.Workbooks;
//建立一個System.Reflection.Missing的object對象
object oMissing = System.Reflection.Missing.Value;
四、打開或新建Excel的book文件
//打開Excel文件,注意里的“ExccelFilePath”為Excel文件在服務器上的物理地址,包括文件名
Workbook myBook = myBooks.Open(ExccelFilePath,oMissing, oMissing, oMissing, oMissing, oMissing, oMissing, oMissing, oMissing, oMissing, oMissing, oMissing, oMissing);
//新建Workseet對象,,此處為要操作的工作表 ,當前要操作的工作表的獲取方法有兩種:使用工作表的索引值或使用工作表的名稱,名稱默認為:“sheet1”/“Sheet2”等
Worksheet mySheet = (Worksheet)myBook.Worksheets[1];
//如果是新建EXCEL工作簿,需要 設置如下兩行內容,以保證工作簿中有一個工作表,
Workbook workbook1 = excel1.Workbooks.Add(true);
Worksheet mySheet= (Worksheet)workbook1.Worksheets["sheet1"];
//設置EXCEL對象是否顯示界面,默認為false不顯示界面
myExcel.Visble=true;
五、一些比較重要的針對Excel的操作
1、獲取Range對象
①、獲取一個單元格的Range對象:
//選擇第一行、第一列的單元的單元格為Range對象
Range r = (Excel.Range)mySheet.Cells[1, 1];
//選擇多個連續的單元格為Range對象
Range r=(Excel.Range)Range.get_Range("A1:F3")
②、給單元格賦值或取出單元格的值:
//已選擇了Range對象的賦值:
r.Text="中國";
//未選擇Range對象的賦值:
mySheet.Cells[1,2].Text="中國";
//已選擇了Range對象的取值:
String strValue= r.Text;
//未選擇Range對象的取值:
String strValue= mySheet.Cells[1,2].Text;
③、給單元格設置邊框
mySheet.Cells[2, 1].BorderAround(XlLineStyle.xlContinuous, XlBorderWeight.xlThin, XlColorIndex.xlColorIndexAutomatic, null);//畫線
④、合并單元格
//合并單元格前先要將要合并的單元格選擇為Range對象
Range r=Range.get_Range("A1:F3");
//然后現設置合并單元格
r.MergeCells = true;
⑤、設置單元格的字體、字號、背景色等屬性
mySheet.Cells[1, 1].Font.Name = "黑體";
mySheet.Cells[1, 1].Font.Size = 20;
mySheet.Rows["1:1"].RowHeight = 40;
mySheet.Cells[1, 1].Interior.Color = Color.FromArgb(224, 224, 224);//設置顏色
⑥、刪除一行:
//首先獲取要刪除的行的Range
Microsoft.Office.Interop.Excel.Range range = (Microsoft.Office.Interop.Excel.Range)mySheet.Rows[sendedRow[1], Type.Missing];
//注意刪除行后刪除后的行號被下面的行替換,如果逐行刪除,請先從最大的行號往最小的行號刪除
range.Delete(Microsoft.Office.Interop.Excel.XlDeleteShiftDirection.xlShiftUp);
⑦、獲取有數據的行數
int rowsint = mySheet.UsedRange.Cells.Rows.Count;
六、EXCEL文件的保存與退出
1、EXCEL的保存與退出
myBook.Save();
myBooks.Close();
myExcel.Quit();
2、EXCEL指定文件保存
myBook.Close(true, FilePath +_file_Name, null);
七、釋放EXCLE對象的資源與結束EXCEL 進程
關于這方面內容有好多網友都在講多種方法,經過本人實踐,以下方面才能真正做到結束EXCEL的任務進程:
1、將所有以上對EXCEL的操作放到一個方法中,
2、在操作EXCEL后,即時將不使用對象一一釋放并賦null值:
System.Runtime.InteropServices.Marshal.ReleaseComObject(mysheet);
mysheet=null;
System.Runtime.InteropServices.Marshal.ReleaseComObject(myBook);
myBook=null;//http://www.111cn.net
System.Runtime.InteropServices.Marshal.ReleaseComObject(myBooks);
myBooks=null;
System.Runtime.InteropServices.Marshal.ReleaseComObject(myExcel);
myExcel=null;
3、再新建一個方法,并以該方法中執行上面新建的操作EXCEL方法,并在執行完操作EXCEL方法的后面添加GC.Collect():
//下面方法中OutPutEXCEL()方法是輸出EXCEL文件的對EXCEL 操作的方法
private void killExcel()
{
outPutEXCEL();
GC.Collect();
GC.WaitForPendingFinalizers();
}
好多網友都在介紹使用GC.Collect()釋放EXCEL占用的資源來結束EXCEL進行,如果將“GC.Collect();”與操作EXCEL的業務寫在一個程序塊中,“GC”是永遠不能結束EXCEL進程的,在WEB應用程序中,這種現象是很可怕的事情。原因是GC不會清理本程序塊中的垃圾內存的。
4、在業務事件中調用killEXCEL()方法:
protected void LinkButton3_Click(object sender, EventArgs e)
{
//導出EXCEL
killExcel();
}
八、一些權限的基本設置:
使用以上方法在開發環境中調試程序沒有一點問題,等發布到服務器上后,程序還是不能正常運行,需要進行如下的權限設置:
1、.NET導出Excel遇到的80070005錯誤的解決方法:
分享:服務器安全狗導致ASP.NET網站運行出錯的一個案例字典中的關鍵字:RegistryPermission所添加的關鍵字:RegistryPermission 報錯,因為服務器上安全狗對.net程序關鍵字過于苛刻引出報錯。 今天碰到一個.net的報錯,之前并沒見過這種報錯,也沒有太多的詳細信息。/應用程序中的服務器錯誤。 字典中的關鍵字:RegistryPermis
- 相關鏈接:
- 教程說明:
.Net教程-asp.net中導出excel數據的方法匯總
。