Winform 导出Excel
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的更多相关文章
- c# winform导出Excel
//需要注意添加引用Microsoft.Office.Interop.Excel.dll string fileName =DateTime.Now.Year+ DateTime.Now.Month+ ...
- winform导出excel
public void AllDataSetToExcel(DataSet ds) { string saveFileName = ""; bool fileSaved = fal ...
- C#导入导出Excel表的数据
一:C#导入导出EXCEL文件的类 代码如下: 首先将Microsoft Excel 14.0 Object Library 引用导入 using System; using System.Data; ...
- winform导入导出excel,后台动态添加控件
思路: 导入: 1,初始化一个OpenFileDialog类 (OpenFileDialog fileDialog = new OpenFileDialog();) 2, 获取用户选择文件的后缀名(s ...
- NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中
以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...
- C# winform 导出导入Excel/Doc 完整实例教程[网上看到的]
还真没做过winform的导出导入,今天上网百度了一下.结果--- 所以还是我自己写个吧.之前做过web的,半搬半做就OK. 1添加引用:Aspose.Cells.dll(我们就叫工具包吧,可以从网上 ...
- 懒人小工具1:winform自动生成Model,Insert,Select,Delete以及导出Excel的方法
懒人小工具2:T4自动生成Model,Insert,Select,Delete以及导出Excel的方法 github地址:https://github.com/Jimmey-Jiang/J ...
- NPOI导入导出EXCEL通用类,可直接使用在WinForm项目中
由于XSSFWorkbook类型的Write方法限制,Write完成后就自动关闭流数据,所以无法很好的支持的Web模式,网上目前也未找到好的解决方案. 注意:若直接使用在WinForm项目中,必需先下 ...
- C#+Aspose.Cells 导出Excel及设置样式 (Webform/Winform)
在项目中用到,特此记录下来,Aspose.Cells 不依赖机器装没有装EXCEL都可以导出,很方便.具体可以参考其他 http://www.aspose.com/docs/display/cells ...
随机推荐
- C语言中将数字转换为字符串的方法
C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串.以下是用itoa()函数将整数转换为字符串的一个例子: # include <stdio. h># ...
- 【python调用windows CLI】调用adb统计Android app的流量消耗
主要记录python如何调用windows CLI 手机连接PC,adb devices可以看到手机sn 通过adb 获取指定app的processID UID 读取Android /proc/ne ...
- Oracle基础 游标
一.游标 游标用来处理从数据库中检索的多行记录(使用SELECT语句).利用游标,程序可以逐个地处理和遍历一次检索返回的整个记录集. 为了处理SQL语句,Oracle将在内存中分配一个区域,这就是上下 ...
- 20145102 《Java程序设计》第5周学习总结
20145102 <Java程序设计>第5周学习总结 教材学习内容总结 数组在内存中会是连续的线性空间,根据索引随机取回时速度快,如果操作上有这类需求时,像是排序,就可以使用;ArrayL ...
- 把当前时间(NSDate)转为字符串 - 获取当前时间的Day
1.把当前时间转为字符串 (NSDate与北京时间相隔8小时,格式化之后就是北京时间) NSDate *date = [NSDate date]; NSDateFormatter *dateForma ...
- UWP源码——Unit Test
之前我们讨论了涨姿势UWP的RSS数据源获取,以及作为文件存储到本地,再将数据转化成Model对象.这部分非UI的内容非常适合添加Unit Test.不涉及UI的话,UT写起来简单高效,很是值得投入一 ...
- Javascript delete 引用类型对象
很少使用javascript的delete,最近因为一个小bug发现删除引用类型对象的时候有一点不同.如下面例子: var testVar = { a : { test : 1 } }, test1 ...
- jQuery简单邮箱验证
function chekmail() { var szReg = /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/; ...
- 另类安装系统——PE工具提取
1. 在当前系统使用安装工具win$man打开,即pe里集成安装工具 2. 选择安装的磁盘或者分区和引导分区 3. 可以默认下一步 4. 不想更改盘符可以默认下一步 5. 最后完成开始安装部署(还需要 ...
- JQuery、js判断复选框是否选中状态
JQuery: var $isChecked = $("#id").is(":checked"); alert($isChecked); JS: var $id ...