winform 导出Execl

转载 2012年03月21日 14:31:10
using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
 using System.Windows.Forms;
 using Microsoft.Office.Interop.Excel;
 namespace SaleApplication.Class
 {
     class ExportExcelOfWinform
     {
         public static bool OutToExcelFromDataGridView(string title, DataGridView dgv, bool isShowExcel)
         {
             int titleColumnSpan = 0;//标题的跨列数
             string fileName = "";//保存的excel文件名
             int columnIndex = 1;//列索引
             if (dgv.Rows.Count == 0)
                 return false;
             /*保存对话框*/
             SaveFileDialog sfd = new SaveFileDialog();
             sfd.Filter = "导出Excel(*.xls)|*.xls";
             sfd.FileName = title + DateTime.Now.ToString("yyyyMMddhhmmss");
             
             if (sfd.ShowDialog() == DialogResult.OK)
             {
                 fileName = sfd.FileName;
                 /*建立Excel对象*/
                 Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
                 if (excel == null)
                 {
                     MessageBox.Show("无法创建Excel对象,可能您的计算机未安装Excel!");
                     return false;
                 }
                 try
                 {
                     excel.Application.Workbooks.Add(true);
                     excel.Visible = isShowExcel;
                     /*分析标题的跨列数*/
                     foreach (DataGridViewColumn column in dgv.Columns)
                     {
                         if (column.Visible == true)
                             titleColumnSpan++;
                     }
                     /*合并标题单元格*/
                     Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)excel.ActiveSheet;
                     //worksheet.get_Range("A1", "C10").Merge();            
                     worksheet.get_Range(worksheet.Cells[1, 1] as Range, worksheet.Cells[1, titleColumnSpan] as Range).Merge();
                     /*生成标题*/
                     excel.Cells[1, 1] = title;
                     (excel.Cells[1, 1] as Range).HorizontalAlignment = XlHAlign.xlHAlignCenter;//标题居中
 //生成字段名称
                     columnIndex = 1;
                     for (int i = 0; i < dgv.ColumnCount; i++)
                     {
                         if (dgv.Columns[i].Visible == true)
                         {
                             excel.Cells[2, columnIndex] = dgv.Columns[i].HeaderText;
                             (excel.Cells[2, columnIndex] as Range).HorizontalAlignment = XlHAlign.xlHAlignCenter;//字段居中
                             columnIndex++;
                         }
                     }
                     //填充数据              
                     for (int i = 0; i < dgv.RowCount; i++)
                     {
                         columnIndex = 1;
                         for (int j = 0; j < dgv.ColumnCount; j++)
                         {
                             if (dgv.Columns[j].Visible == true)
                             {
                                 if (dgv[j, i].ValueType == typeof(string))
                                 {
                                     excel.Cells[i + 3, columnIndex] = "'" + dgv[j, i].Value.ToString();
                                 }
                                 else
                                 {
                                     excel.Cells[i + 3, columnIndex] = dgv[j, i].Value.ToString();
                                 }
                                 (excel.Cells[i + 3, columnIndex] as Range).HorizontalAlignment = XlHAlign.xlHAlignLeft;//字段居中
                                 columnIndex++;
                             }
                         }
                     }
                     worksheet.SaveAs(fileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);  
                 }
                 catch { }
                 finally
                 {  
                     excel.Quit(); 
                     excel = null;
                     GC.Collect();
                 }
                 //KillProcess("Excel");
                 return true;
             }
             else
             {
                 return false;
             }
         }
         private static void KillProcess(string processName)//杀死与Excel相关的进程
         {
             System.Diagnostics.Process myproc = new System.Diagnostics.Process();//得到所有打开的进程
             try
             {
                 foreach (System.Diagnostics.Process thisproc in System.Diagnostics.Process.GetProcessesByName(processName))
                 {
                     if (!thisproc.CloseMainWindow())
                     {
                         thisproc.Kill();
                     }
                 }
             }
             catch (Exception Exc)
             {
                 throw new Exception("", Exc);
             }
         }
 
     }
 }

 

C# WinForm下Excel导入导出

C# WinForm下Excel导入导出 //引用命名空间   using Microsoft.Office.Interop.Excel; //DataGridView 导出到Excel  ...
  • kingmax54212008
  • kingmax54212008
  • 2014年11月10日 22:32
  • 2480

C#读取和导出EXCEL类库(可操作多个SHEET)

改进的一个EXCEL类,可以读取EXCEL,也可以将内容导出到EXCEL.操作多个SHEET比较方便. 而且无须安装任何EXCEL. 1.读取. public void Read(str...
  • hwm831002
  • hwm831002
  • 2013年09月30日 10:59
  • 6675

C# DataGridView 导出Excle代码和总结(转)

http://www.cnblogs.com/loveqin24/archive/2012/04/09/2439071.html 1、导出很快的方式; 1.1、设置数字不以科学...
  • u011981242
  • u011981242
  • 2016年04月20日 09:16
  • 1486

winForm中导出Execl的方法

winForm中导出Execl的方法:   1、方法1:    SqlConnection conn=new SqlConnection(System.Configuration.Configu...
  • wuhongyao3
  • wuhongyao3
  • 2012年06月27日 09:34
  • 442

WinForm中导出Execl的方法(详解)

  • 2013年05月02日 10:06
  • 70KB
  • 下载

winform Execl数据 导入到数据库(SQL)

首先,看一下我的窗体设计:
  • u013816709
  • u013816709
  • 2014年05月09日 20:52
  • 619

数据库导数据到Execl(winform)

  • 2012年08月31日 14:29
  • 1.15MB
  • 下载

WinForm_DataSet导入execl

  • 2008年10月09日 16:27
  • 8KB
  • 下载

java对Execl的导入导出

如何实现在java平台对execl的操作?
  • u011707402
  • u011707402
  • 2015年01月19日 21:10
  • 354

java使用apache.poi SXSSFWorkbook导出大数据的execl表格并下载

//通过部门id导出大数据的execl public void exportFileBydId(HttpServletResponse response,String[] dIds) { Simp...
  • weixin_37038880
  • weixin_37038880
  • 2017年11月03日 10:08
  • 328
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:winform 导出Execl
举报原因:
原因补充:

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