国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

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

2024-07-10 12:52:48
字體:
來源:轉載
供稿:網友

推薦: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下一頁
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 天峻县| 宜川县| 桐柏县| 武冈市| 辛集市| 达日县| 青冈县| 阳西县| 新丰县| 汶川县| 栾川县| 青冈县| 嘉荫县| 唐山市| 民勤县| 徐水县| 洛浦县| 上饶市| 财经| 米易县| 大丰市| 麻栗坡县| 茌平县| 井陉县| 浙江省| 济源市| 香格里拉县| 巴彦县| 丹江口市| 江孜县| 平潭县| 淮滨县| 沙洋县| 潞西市| 武威市| 榕江县| 韶山市| 肃宁县| 绥江县| 会昌县| 盖州市|