asp.net中導出excel數據的方法匯總_.Net教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦: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

      共2頁上一頁12下一頁
      來源:模板無憂//所屬分類:.Net教程/更新時間:2014-10-10
      相關.Net教程