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. dp与px之间的转换

    代码如下: package com.example.fxvideo.utils; import android.content.Context; public class DensityUtils { ...

  2. [转]Android中内存占用的含义:(VSS,PSS,RSS,USS)

    Android中内存占用的含义:(VSS,PSS,RSS,USS) 作者: andforce 分类: 安卓系统 发布时间: 2013-09-07 00:03 ė1,915 浏览数 6没有评论 在eng ...

  3. Android(java)学习笔记67:多线程程序练习

    需求: 某电影院目前正在上映贺岁大片,共有100张票,而它有3个售票窗口售票,请设计一个程序模拟该电影院售票. 两种方式实现 A:继承Thread类 B:实现Runnable接 1. 首先我们利用方式 ...

  4. 【JS对象、JSON字符串】之间的相互转换

    在Firefox,chrome,opera,safari,ie9,ie8等浏览器直接可以用JSON对象的stringify()和parse()方法. 1.JSON.stringify(obj)将JS对 ...

  5. KDE声音服务器 arts

    KDE声音服务器 arts arts介绍arts是KDE的核心声音系统,支持多音频流.全双工.网络声音请求.ALSA与OSS驱动后端.JACK声音服务器后端等扩展,它既是声音服务器,也 提供一套音频软 ...

  6. HDU 4424 Conquer a New Region

    http://acm.hdu.edu.cn/showproblem.php?pid=4424 [题目大意] 给你N个点和N-1条边的连通图,也就是说任意两点间的路径是唯一的.每条边有个权值,从一点到另 ...

  7. php用curl获取远端网页内容

    <?php $url="http://www.baidu.com";$cc=curl_init(); curl_setopt($cc,CURLOPT_URL,$url); c ...

  8. uva 12544 无向图最小环

    思路:这题的N有500,直接floyd肯定超时. 我的做法是每次枚举一个点,求出包含这个点的最小环. 对所有最小环取最小值.求包含某个点的最小环我用的是启发式搜索,先以该点求一次spfa,然后dfs解 ...

  9. 基调(听云)app,服务器,质量测试手段

    1. 网络质量检测 http://www.tingyun.com/tingyun_network.html

  10. vijos 1053Easy sssp

    P1053Easy sssp Accepted 标签:图结构 最短路     描述 输入数据给出一个有N(2 <= N <= 1,000)个节点,M(M <= 100,000)条边的 ...