c# listview导出excel文件
首先在工程中需要添加对Microsoft Excel office 11.0 object的引用
生成excel的类代码如下
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace LvwToExcel
{
class CExcel
{
/// <summary>
/// 导出Excel文件
/// </summary>
/// <param name="lvwShow">数据源</param>
/// <param name="strExcelTitle">Excel文件名</param>
public void LvwToExcel(ListView lvwShow,string strExcelName)
{
int row = lvwShow.Items.Count;//listview行数
int col = lvwShow.Items[0].SubItems.Count;//listview列数
if (row == 0 || string.IsNullOrEmpty(strExcelName))
{
return;
}
if (row > 0)
{
Microsoft.Office.Interop.Excel._Application ExcelApp = new Microsoft.Office
.Interop.Excel.Application();
if (ExcelApp == null)
{
MessageBox.Show("无法创建Excel对象,可能你的系统没有安装Excel!!!");
return;
}
object m_objOpt = System.Reflection.Missing.Value;
Microsoft.Office.Interop.Excel.Workbooks ExcleBooks = (Microsoft.Office.Interop.Excel.Workbooks)ExcelApp.Workbooks;
Microsoft.Office.Interop.Excel._Workbook ExcleBook=(Microsoft.Office.Interop.Excel._Workbook )(ExcleBooks.Add(m_objOpt));
Microsoft.Office.Interop.Excel._Worksheet ExcelSheet = (Microsoft.Office.Interop.Excel._Worksheet)ExcleBook.ActiveSheet;
ExcelApp.Visible = true;
//读取listview表头做为excel列标题,listview中,行和列的下标索引都是从0开始
for (int i = 1; i <= col; i++)
{
ExcelSheet.Cells[1, i] = lvwShow.Columns[i-1].Text;
}
for (int i = 0; i <row; i++)
{
ExcelSheet.Cells[i+2, 1] = lvwShow.Items[i].Text;//获取所有行第一列的值
for (int j = 1; j < col; j++)
{
ExcelSheet.Cells[i+2, j+1] = lvwShow.Items[i].SubItems[j].Text;//获取某一行某一列的值
}
}
ExcleBook.SaveAs(strExcelName);
//ExcelApp.Quit();//退出excel
ExcelApp = null;
ExcelSheet = null;
ExcleBooks = null;
ExcleBook = null;
}
}
/// <summary>
/// 保存Excel文件
/// </summary>
public void ExportExcel(ListView lvwShow)
{
SaveFileDialog sfd = new SaveFileDialog();
sfd.DefaultExt = "xls";
sfd.Filter = "Excel文件(*.xls)|*.xls";
if (sfd.ShowDialog() == DialogResult.OK)
{
LvwToExcel(lvwShow,sfd.FileName);
}
}
}
}
二winform窗体中添加一个Listview控件具体代码如下
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data;
using System.Data.SqlClient;
namespace LvwToExcel
{
public partial class FrmToExcel : Form
{
private SqlConnection con=new SqlConnection();
public FrmToExcel()
{
InitializeComponent();
}
public void initLvw()
{
listViewShow.FullRowSelect = true;
listViewShow.GridLines = true;
listViewShow.MultiSelect = false;
listViewShow.View = View.Details;
listViewShow.HideSelection = false;
listViewShow.Columns.Add("1", 100, HorizontalAlignment.Center);
listViewShow.Columns.Add("2", 100, HorizontalAlignment.Center);
listViewShow.Columns.Add("3", 100, HorizontalAlignment.Center);
listViewShow.Columns.Add("4", 100, HorizontalAlignment.Center);
}
private void FrmToExcel_Load(object sender, EventArgs e)
{
initLvw();
//连接数据库
string sqlConnect = "initial catalog=数据库名;server='服务器名';uid=sa;pwd=密码";
con = new SqlConnection(sqlConnect);
con.Open();
SqlDataReader DR;
SqlCommand sqlcom = new SqlCommand();
sqlcom.Connection = con;
string sqlStr = "select top 5 1,2,3,4 from item";
sqlcom.CommandText = sqlStr;
DR = sqlcom.ExecuteReader();
LvwShowTable(DR);
}
private void LvwShowTable(SqlDataReader dr)
{
//读取表中记录
while (dr.Read())
{
ListViewItem li = new ListViewItem();
li.SubItems.Clear();
li.SubItems[0].Text = dr["1"].ToString()==""?"NULL":dr["1"].ToString();
li.SubItems.Add(dr["2"].ToString() == "" ? "NULL" : dr["2"].ToString());
li.SubItems.Add(dr["3"].ToString()==""?"NULL":dr["3"].ToString());
li.SubItems.Add(dr["4"].ToString()==""?"NULL":dr["4"].ToString());
listViewShow.Items.Add (li);
}
}
private void btnToExcel_Click(object sender, EventArgs e)
{
CExcel excel = new CExcel();
excel.ExportExcel(listViewShow);
}
}
}
c# listview导出excel文件的更多相关文章
- ExtJS Grid导出excel文件
ExtJS Grid导出excel文件, 需下载POI:链接:http://pan.baidu.com/s/1i3lkPhF 密码:rqbg 1.将Grid表格数据连同表格列名传到后台 2.后台导出e ...
- PHP从数据库导出EXCEL文件
参考博客链接:http://www.cnblogs.com/huangcong/p/3687665.html 我的程序代码 原生导出Excel文件 <?phpheader('Content-ty ...
- jxl导出Excel文件
一.java项目实现读取Excel文件和导出Excel文件 实现读取和导出Excel文件的代码: package servlet; import java.io.FileInputStream; im ...
- PHP导出excel文件
现在教教你如何导入excel文件: 在我的文件储存里面有一个com文件夹的,将其解压放在ThinkPHP/Library/文件夹里面,然后就是写控制器啦!去调用这个插件: <?php names ...
- 【转】 (C#)利用Aspose.Cells组件导入导出excel文件
Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...
- PHPExcel导出excel文件
今天园子刚开,先来个货顶下,后续园丁qing我会再慢慢种园子的,希望大家多来园子逛逛. PHPExcel导出excel文件,先说下重要的参数要记住的东西 impUser() 导入方法 exportEx ...
- 导出Excel文件
/// <summary> /// 类说明:Assistant /// 更新网站:[url=http://www.sufeinet.com/thread-655-1-1.html]http ...
- 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法
-----转载:http://blog.csdn.net/sgear/article/details/7663502 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格 ...
- MSSQL2005 导出excel文件
Title:MSSQL2005 导出excel文件 --2011-01-16 16:01 EXEC master..xp_cmdshell 'bcp "select * from 数据库名 ...
随机推荐
- 05-UIKit(UITableViewController)
目录: 一.UITableViewController(表视图控制器) 二.委托协议 三.tableview工作过程(三问一响应) 四.UITableViewCell 回到顶部 一.UITableVi ...
- Orleans is a framework
Introduction Orleans is a framework that provides a straightforward approach to building distributed ...
- Web网页中内嵌Activex的Activex插件开发 .
转载自: http://blog.csdn.net/tttyd/article/details/5258096 源代码下载 http://files.cnblogs.com/tttyd/Activex ...
- Java基础02 方法与数据成员
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 在Java基础01 从HelloWorld到面向对象,我们初步了解了对象(obje ...
- python对web服务器做压力测试并做出图形直观显示
压力测试有很多工具啊.apache的,还有jmeter, 还有loadrunner,都比较常用. 其实你自己用python写的,也足够用. 压力测试过程中要统计时间. 比如每秒的并发数,每秒的最大响应 ...
- Java EE登陆界面生成随机数防止恶意注册或者登录
package cn.com; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.a ...
- 基于W5500+Yeelink的远程灯光控制设计
概述 工具:物联网云平台Yeelink DHT11温湿度传感器 W5500EVB 编译环境:Keil4 目的:通过以太网实时监控远程某个位置的温度和湿度 在W5500EVB端连接LED灯.通过W ...
- 讲解下for循环的用法,加深记忆
引子 这是一段很简单的代码,但是即便是这么简单的东西,这里我们还是需要说一下. 关于for循环整个执行流程就是,先执行var i=10,然后到了第二个语句,判断10是否大于0,很明显为true,所以此 ...
- vc怎么去掉烦人的“驱动器未准备好”错误
在我们写程序的时候,如果访问一个软驱中没有软盘或者光驱中没有cd的时候,windows总是弹出一个恼人的错误框说“驱动器未准备好” 其实我们可以通过如下的步骤禁止这个错误框的弹出 一.用SetErro ...
- MSSQL - 自增1的标识列一次增长了1000
@情若天_RunUp: 1. Open "SQL Server Configuration Manager"2. Click "SQL Server Services&q ...