DataGrid - 导出Excel文件

原创 2004年10月28日 09:22:00

方法有很多,我只用了最简单的方法

1.引用 COM组件 Excel.dll

2.实现如下

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);
   
  }

easyUI datagrid导出excel(所见即所得)

实现主要用到网友写的一个扩展jeasyui.extensions.datagrid.export.js调用方法简单,直接下载实例代码吧!http://yunpan.cn/cF7sydr9Kk7fi ...
  • cctvcqupt
  • cctvcqupt
  • 2015年11月03日 16:58
  • 851

easyui Jquery datagrid 导出Excel(转)

Jquery easyui datagrid 导出Excel(转) datagrid的扩展方法,用于将当前的数据生成excel需要的内容。   1 2 ...
  • springflower66
  • springflower66
  • 2016年06月29日 08:14
  • 3101

jquery easyui datagrid纯js导出到excel

说明:easyui本身的datagrid不支持导出excel,查了一些资料后的结合后端代码实现导出功能的都是C#, 下面的例子使用jquery前端代码导出excel          主要的方法是使用...
  • current_person
  • current_person
  • 2016年01月21日 14:07
  • 9284

VB.net中DataGrid导出为Excel文件函数

Public Function ExportXLsD(ByVal datagrid As DataGrid) ', ByVal Title As String) 'Dim Mytab...
  • fjnu2008
  • fjnu2008
  • 2012年07月31日 11:18
  • 1360

JS导出datagrid导出Excel

function ExproterAll() { var rows = $('#dg').datagrid('getRows'); //var rows=$('#dg').datagrid("ge...
  • suifeng411
  • suifeng411
  • 2015年10月21日 13:32
  • 1213

easyui中前台利用js导出显示的datagrid

第一步:添加datagrid 的扩展属性(可以写在通用js文件中) /** Jquery easyui datagrid js导出excel 修改自extgrid导出excel...
  • hb0746
  • hb0746
  • 2015年01月09日 22:33
  • 9108

EasyUI----DataGrid 导出 Excel

最近做的安防项目有个功能,需要把DataGrid中的数据导出,下面通过代码一步一步的介绍; 首先在js中写一个扩展类,主要的功能是把DataGrid中的数据转换成Excel的XML格式...
  • u010853701
  • u010853701
  • 2015年08月16日 17:40
  • 7006

Easy UI DataGrid 导出Excel表格

大体介绍一下,前后端完全分离。前端html5,后台用的asp.net的一般处理程序。 自己写了一个单独的js来实现报表的导出,因为客户对于报表的样式要求不是很高,所以做成这样基本够用了。 接下来贴...
  • DrawDream
  • DrawDream
  • 2015年09月02日 13:54
  • 3544

MVC项目中如何用JS导出EasyUI DataGrid为Excel

在做一中考评项目的时候,遇到了这么一个需求,就是把评教后得到的老师的成绩导出为Excel。其实需求很普通,实现起来有些复杂,因为老师考评不但有固定的考核项,还有额外加分项。于是我们就抽出来了一个表,专...
  • u013038861
  • u013038861
  • 2016年01月03日 21:50
  • 3949

wpf导出DataGrid到Excel

public static void ExportDataGrid(DataGrid dGrid)         {             SaveFileDialog objSFD = ne...
  • qiangzi9009
  • qiangzi9009
  • 2014年11月04日 15:07
  • 1614
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:DataGrid - 导出Excel文件
举报原因:
原因补充:

(最多只允许输入30个字)