private void 导出excelToolStripMenuItem_Click(object sender, EventArgs e)
{
if (dgvData.RowCount > )
{
var saveFileDialog1 = new SaveFileDialog
{
Filter = @"Excel文件(*.xls,*.xlsx)|*.xls;*.xlsx",
RestoreDirectory = true
}; if (saveFileDialog1.ShowDialog() == DialogResult.OK)
{
var result = _excel.SetExportExcel(saveFileDialog1.FileName, dgvData, );
if (result != null)
{
MessageBox.Show(result.HasError ? "文件导出成功!!" : result.ErrorMessage);
}
}
}
else
{
MessageBox.Show(@"数据为空!!");
}
} /// <summary>
/// DataGridView 导出Excel方法
/// </summary>
/// <param name="fileName">导出路径</param>
/// <param name="gridView">数据源</param>
/// <param name="num">从第几列开始导</param>
public Result SetExportExcel(string fileName, DataGridView gridView, int num)
{
var result = new Result(); if (fileName.IndexOf(":") > )
{
Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application(); if (xlApp == null)
{
result.ErrorMessage = "无法创建Excel对象,可能您的机子未安装Excel";
result.HasError = false;
}
Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;
Microsoft.Office.Interop.Excel.Workbook workbook =
workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
Microsoft.Office.Interop.Excel.Worksheet worksheet =
(Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[]; //取得sheet1 int a = , b = ;
for (var i = ; i < gridView.RowCount; i++)
{
if (i == )
{
for (var j = num; j < gridView.Columns.Count; j++)
{
worksheet.Cells[, a] = gridView.Columns[j].HeaderText;
a++;
}
}
for (var j = num; j < gridView.Columns.Count; j++)
{
worksheet.Cells[i + , b] = gridView.Rows[i].Cells[j].Value;
b++;
}
b = ;
System.Windows.Forms.Application.DoEvents();
} worksheet.Columns.EntireColumn.AutoFit(); //列宽自适应
if (fileName != "")
{
try
{
workbook.Saved = true;
workbook.SaveCopyAs(fileName);
}
catch (Exception ex)
{
result.ErrorMessage = "文件导出时出错,文件可能正被打开!" + ex.Message;
result.HasError = false;
}
}
xlApp.Quit();
GC.Collect(); //强行销毁
result.HasError = true;
}
return result;
} /// <summary>
/// ListView 导出Excel方法
/// </summary>
/// <param name="fileName">导出路径</param>
/// <param name="listView">数据源</param>
/// <param name="num">从第几列开始导</param>
public Result SetListViewExportExcel(string fileName, ListView listView, int num)
{
var result = new Result(); if (fileName.IndexOf(":") > )
{
Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application(); if (xlApp == null)
{
result.ErrorMessage = "无法创建Excel对象,可能您的机子未安装Excel";
result.HasError = false;
}
Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;
Microsoft.Office.Interop.Excel.Workbook workbook =
workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
Microsoft.Office.Interop.Excel.Worksheet worksheet =
(Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[]; //取得sheet1 int a = , b = ;
for (var i = ; i < listView.Items.Count; i++)
{
if (i == )
{
for (var j = num; j < listView.Columns.Count; j++)
{
worksheet.Cells[, a] = listView.Columns[j].Text;
a++;
}
}
for (var j = num; j < listView.Columns.Count; j++)
{
worksheet.Cells[i + , b] = listView.Items[i].SubItems[j].Text;
b++;
}
b = ;
System.Windows.Forms.Application.DoEvents();
} worksheet.Columns.EntireColumn.AutoFit(); //列宽自适应
if (fileName != "")
{
try
{
workbook.Saved = true;
workbook.SaveCopyAs(fileName);
}
catch (Exception ex)
{
result.ErrorMessage = "文件导出时出错,文件可能正被打开!" + ex.Message;
result.HasError = false;
}
}
xlApp.Quit();
GC.Collect(); //强行销毁
result.HasError = true;
}
return result;
}

Winform 导出Excel的更多相关文章

  1. c# winform导出Excel

    //需要注意添加引用Microsoft.Office.Interop.Excel.dll string fileName =DateTime.Now.Year+ DateTime.Now.Month+ ...

  2. winform导出excel

    public void AllDataSetToExcel(DataSet ds) { string saveFileName = ""; bool fileSaved = fal ...

  3. C#导入导出Excel表的数据

    一:C#导入导出EXCEL文件的类 代码如下: 首先将Microsoft Excel 14.0 Object Library 引用导入 using System; using System.Data; ...

  4. winform导入导出excel,后台动态添加控件

    思路: 导入: 1,初始化一个OpenFileDialog类 (OpenFileDialog fileDialog = new OpenFileDialog();) 2, 获取用户选择文件的后缀名(s ...

  5. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  6. C# winform 导出导入Excel/Doc 完整实例教程[网上看到的]

    还真没做过winform的导出导入,今天上网百度了一下.结果--- 所以还是我自己写个吧.之前做过web的,半搬半做就OK. 1添加引用:Aspose.Cells.dll(我们就叫工具包吧,可以从网上 ...

  7. 懒人小工具1:winform自动生成Model,Insert,Select,Delete以及导出Excel的方法

       懒人小工具2:T4自动生成Model,Insert,Select,Delete以及导出Excel的方法    github地址:https://github.com/Jimmey-Jiang/J ...

  8. NPOI导入导出EXCEL通用类,可直接使用在WinForm项目中

    由于XSSFWorkbook类型的Write方法限制,Write完成后就自动关闭流数据,所以无法很好的支持的Web模式,网上目前也未找到好的解决方案. 注意:若直接使用在WinForm项目中,必需先下 ...

  9. C#+Aspose.Cells 导出Excel及设置样式 (Webform/Winform)

    在项目中用到,特此记录下来,Aspose.Cells 不依赖机器装没有装EXCEL都可以导出,很方便.具体可以参考其他 http://www.aspose.com/docs/display/cells ...

随机推荐

  1. go can't find import: "github.com/** 错误

    go get 后 go build 错误 can't find import: "github.com/ 原因: 1.gopath 没配好 2.go get 后要先 go install , ...

  2. CALayer实现点击屏幕放大或者缩小的一个圆

    #import "ViewController.h" #define WIDTH 50 @interface ViewController () @end @implementat ...

  3. Socket 使用笔记与注意事项(一)

    SocketAsyncEventArgs 1.该参数可以重复使用. 2.SocketAsyncEventArgs 的事件执行触发之后可以使用. 3.SocketAsyncEventArgs 的事件还在 ...

  4. leetcode题解:Binary Tree Postorder Traversal (二叉树的后序遍历)

    题目: Given a binary tree, return the postorder traversal of its nodes' values. For example:Given bina ...

  5. iOS 中的加密方式

    iOS 中的加密方式 1 加密方式主要有: Base64,MD5,RSA,DES,AES,钥匙串存储,Cookie 2 各加密方式的比较 2.1 Base64 2.1.1 基本原理:采用64个基本的 ...

  6. 《MFC游戏开发》笔记三 游戏贴图与透明特效的实现

    本系列文章由七十一雾央编写,转载请注明出处. 313239 作者:七十一雾央 新浪微博:http://weibo.com/1689160943/profile?rightmod=1&wvr=5 ...

  7. Ubuntu14.04 搭建 node.js 环境(Binaries方式)

    从官网下载 http://nodejs.org/download/ Linux Binaries (.tar.gz)  下载下来的是node-v0.10.29-linux-x64.tar.gz文件 解 ...

  8. Python时间,日期,时间戳之间转换

    1.将字符串的时间转换为时间戳     方法:         a = "2013-10-10 23:40:00"         将其转换为时间数组         import ...

  9. hdu 3234 并查集

    虚拟一个根节点n,设其值为0.并且始终保持其为根. #include<map> #include<set> #include<cmath> #include< ...

  10. poj 1330 Nearest Common Ancestors 裸的LCA

    #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #i ...