导出EXCEL

找了个导出EXCEL的方法,先要引用Microsoft Office 11.0 Object Library和Microsoft Excel 11.0 Object Library

在COM组件里找

然后引用

using Office = Microsoft.Office.Core;
using Excel = Microsoft.Office.Interop.Excel;

public void ExportExcel(){
   DataSet ds=this.DataSet;//取得dataGrid绑定的DataSet
   if(ds==null) return;

   string saveFileName="";
   bool fileSaved=false;
   SaveFileDialog saveDialog=new SaveFileDialog();
   saveDialog.DefaultExt ="xls";
   saveDialog.Filter="Excel文件|*.xls";
   saveDialog.FileName ="Sheet1";
   saveDialog.ShowDialog();
   saveFileName=saveDialog.FileName;
   if(saveFileName.IndexOf(":")<0) return; //被点了取消
  
   Excel.Application xlApp=new Excel.Application();

   if(xlApp==null){
    MessageBox.Show("无法创建Excel对象,可能您的机子未安装Excel");
    return;
   }

   Excel.Workbooks workbooks=xlApp.Workbooks;
   Excel.Workbook workbook=workbooks.Add(Excel.XlWBATemplate.xlWBATWorksheet);
   Excel.Worksheet worksheet=(Excel.Worksheet)workbook.Worksheets[1];//取得sheet1
   Excel.Range range;

   string oldCaption=this.CaptionText;
            long totalCount=ds.Tables[0].Rows.Count;
   long rowRead=0;
   float percent=0;

   worksheet.Cells[1,1]=this.CaptionText;
   //写入字段
   for(int i=0;i<ds.Tables[0].Columns.Count;i++){
    worksheet.Cells[2,i+1]=ds.Tables[0].Columns[i].ColumnName; 
    range=(Excel.Range)worksheet.Cells[2,i+1];
    range.Interior.ColorIndex = 15;
    range.Font.Bold = true;
 
   }
   //写入数值
   this.CaptionVisible = true;
   for(int r=0;r<ds.Tables[0].Rows.Count;r++){
    for(int i=0;i<ds.Tables[0].Columns.Count;i++){
     worksheet.Cells[r+3,i+1]=ds.Tables[0].Rows[r][i];    
    }
    rowRead++;
    percent=((float)(100*rowRead))/totalCount;   
    this.CaptionText = "正在导出数据["+ percent.ToString("0.00")  +"%]...";
    Application.DoEvents();
   }
   this.CaptionVisible = false;
   this.CaptionText = oldCaption;

   range=worksheet.get_Range(worksheet.Cells[2,1],worksheet.Cells[ds.Tables[0].Rows.Count+2,ds.Tables[0].Columns.Count]);
   range.BorderAround(Excel.XlLineStyle.xlContinuous,Excel.XlBorderWeight.xlThin,Excel.XlColorIndex.xlColorIndexAutomatic,null);
  
   range.Borders[Excel.XlBordersIndex.xlInsideHorizontal].ColorIndex = Excel.XlColorIndex.xlColorIndexAutomatic;
   range.Borders[Excel.XlBordersIndex.xlInsideHorizontal].LineStyle =Excel.XlLineStyle.xlContinuous;
   range.Borders[Excel.XlBordersIndex.xlInsideHorizontal].Weight =Excel.XlBorderWeight.xlThin;

   if(ds.Tables[0].Columns.Count>1){
    range.Borders[Excel.XlBordersIndex.xlInsideVertical].ColorIndex =Excel.XlColorIndex.xlColorIndexAutomatic;
    range.Borders[Excel.XlBordersIndex.xlInsideVertical].LineStyle = Excel.XlLineStyle.xlContinuous;
    range.Borders[Excel.XlBordersIndex.xlInsideVertical].Weight = Excel.XlBorderWeight.xlThin;
   }

   if(saveFileName!=""){   
    try{
     workbook.Saved =true;  
     workbook.SaveCopyAs(saveFileName);
     fileSaved=true;
    }catch(Exception ex){
     fileSaved=false;
     MessageBox.Show("导出文件时出错,文件可能正被打开!/n"+ex.Message);
    }
   }else{
    fileSaved=false;
   }  
   xlApp.Quit();  
   GC.Collect();//强行销毁
   if(fileSaved && File.Exists(saveFileName)) System.Diagnostics.Process.Start(saveFileName);
  
  }

WORD的操作类似


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值