当前位置:  编程技术>.net/c#/asp.net

c# 保存listView数据为excel文件的二种方法

    来源: 互联网  发布时间:2014-08-30

    本文导语:  以下代码实现: 把listView中的数据保存成Excle。 方法1,保存listView数据为excel文件。 代码:   代码示例: using System.IO; using Microsoft.Office.Interop.Excel; public static void ExportToExcel(ListView pListView) {     if (pListView.Items == null) return...

以下代码实现:
把listView中的数据保存成Excle。

方法1,保存listView数据为excel文件。
代码:
 

代码示例:

using System.IO;
using Microsoft.Office.Interop.Excel;
public static void ExportToExcel(ListView pListView)
{
    if (pListView.Items == null) return;

    string saveFileName = "";
    SaveFileDialog saveDialog = new SaveFileDialog();
    saveDialog.DefaultExt = "xls";
    saveDialog.Filter = "Excel文件|*.xls";
    saveDialog.FileName = DateTime.Now.ToString("yyyy-MM-dd");
    saveDialog.ShowDialog();
    saveFileName = saveDialog.FileName;
    if (saveFileName.IndexOf(":") < 0)
    return;
    //这里直接删除,因为saveDialog已经做了文件是否存在的判断
    if (File.Exists(saveFileName)) File.Delete(saveFileName);
    Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application();
    if (xlApp == null)
    {
     MessageBox.Show("无法创建Excel对象,可能您的机器未安装Excel");
     return;
    }
    Microsoft.Office.Interop.Excel.Workbooks workbooks = xlApp.Workbooks;
    Microsoft.Office.Interop.Excel.Workbook workbook = workbooks.Add(true);
    Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];
    xlApp.Visible = false;
    //填充列
    for (int i = 0; i < pListView.Columns.Count; i++)
    {
    worksheet.Cells[1, i + 1] = pListView.Columns[i].Text.ToString();
((Microsoft.Office.Interop.Excel.Range)worksheet.Cells[1, i + 1]).Font.Bold = true;
    }
    //填充数据(这里分了两种情况,1:lv带CheckedBox,2:不带CheckedBox)

    //带CheckedBoxes
    if (pListView.CheckBoxes == true)
    {
int tmpCnt = 0;
for (int i = 0; i < pListView.Items.Count; i++)
{
    if (pListView.Items[i].Checked == true)
    {
for (int j = 0; j < pListView.Columns.Count; j++)
{
    if (j == 0)
    {
worksheet.Cells[2 + tmpCnt, j + 1] = pListView.Items[i].Text.ToString();
((Microsoft.Office.Interop.Excel.Range)worksheet.Cells[2 + tmpCnt, j + 1]).HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
    }
    else
    {
worksheet.Cells[2 + tmpCnt, j + 1] = pListView.Items[i].SubItems[j].Text.ToString();
((Microsoft.Office.Interop.Excel.Range)worksheet.Cells[2 + tmpCnt, j + 1]).HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
    }
}
tmpCnt++;
    }
}
    }
    else //不带Checkedboxe
    {
for (int i = 0; i < pListView.Items.Count; i++)
{
    for (int j = 0; j < pListView.Columns.Count; j++)
    {
if (j == 0)
{
    worksheet.Cells[2 + i, j + 1] = pListView.Items[i].Text.ToString();
    ((Microsoft.Office.Interop.Excel.Range)worksheet.Cells[2 + i, j + 1]).HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
}
else
{
    worksheet.Cells[2 + i, j + 1] = pListView.Items[i].SubItems[j].Text.ToString();
    ((Microsoft.Office.Interop.Excel.Range)worksheet.Cells[2 + i, j + 1]).HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
}
    }
}
    }
    object missing = System.Reflection.Missing.Value;
    try
    {
workbook.Saved = true;
workbook.SaveAs(saveFileName, Microsoft.Office.Interop.Excel.XlFileFormat.xlXMLSpreadsheet, missing, missing, false, false, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, missing, missing, missing, missing, missing);
    }
    catch (Exception e1)
    {
MessageBox.Show("导出文件时出错,文件可能正被打开!n" + e1.Message);
    }
    finally
    {
xlApp.Quit();
System.GC.Collect();
    }
    MessageBox.Show("导出Excle成功!");
}

方法2,保存listView数据为excel文件。
代码:
 

代码示例:

using Microsoft.Office.Interop.Excel;
using ExcelApplication = Microsoft.Office.Interop.Excel.Application;
using System.Reflection;

public void TurnToExcel(ListView listView, string stname)
{
    string Sheetname = stname;
    ListView listView1 = listView;
    if (listView1.Items.Count < 1)
    return;
    try
    {
      ExcelApplication MyExcel = new ExcelApplication();
      MyExcel.Visible = true;
      if (MyExcel == null)
      {
         return;
      }
Workbooks MyWorkBooks = (Workbooks)MyExcel.Workbooks;
Workbook MyWorkBook = (Workbook)MyWorkBooks.Add(Missing.Value);
Worksheet MyWorkSheet = (Worksheet)MyWorkBook.Worksheets[1];

Range MyRange = MyWorkSheet.get_Range("A1", "H1");
MyRange = MyRange.get_Resize(1, listView1.Columns.Count);
object[] MyHeader = new object[listView1.Columns.Count];
for (int i = 0; i < listView1.Columns.Count; i++)
{
    MyHeader.SetValue(listView1.Columns[i].Text, i);
}
MyRange.Value2 = MyHeader;
MyWorkSheet.Name = Sheetname;

if (listView1.Items.Count > 0)
{
    MyRange = MyWorkSheet.get_Range("A2", Missing.Value);

    object[,] MyData = new Object[listView1.Items.Count, listView1.Columns.Count];
    for (int j = 0; j < listView1.Items.Count; j++)
    {
ListViewItem lvi = listView.Items[j];
for (int k = 0; k < listView1.Columns.Count; k++)
{
 MyData[j, k] = lvi.SubItems[k].Text;
}
}
MyRange = MyRange.get_Resize(listView1.Items.Count, listView1.Columns.Count);
MyRange.Value2 = MyData;
MyRange.EntireColumn.AutoFit();
}
MyExcel = null;
}
catch (Exception Err)
{
MessageBox.Show(Err.Message);
}
}

备注:
以上代码记得添加Excel引用:Microsoft.Office.Interop.Excel


    
 
 

您可能感兴趣的文章:

  • c#读取图像保存到数据库(数据库保存图片)实例
  • c#读取图像保存到数据库中(数据库保存图片)
  • C#实现将网页保存成图片的网页拍照功能
  • c#实现winform屏幕截图并保存的示例
  • C#将Sql数据保存到Excel文件中的方法
  • C#中按指定质量保存图片的实例代码
  • C#按指定质量保存图片的实现代码
  • c# 自动与手动保存图片的代码
  • 使用C#在注册表中保存信息的例子
  • C# 手动/自动保存图片的实例代码
  • c#基础 动态打开,显示,保存,另存为 图片
  • C#缩略图多路径多格式保存的实例
  • C#保存图片到数据库并读取显示图片的方法
  • C#实现上传照片到物理路径,并且将地址保存到数据库的小例子
  • c#保存窗口位置大小操作类(序列化和文件读写功能)
  • C# 实现的图片盖章功能,支持拖拽、旋转、放缩、保存
  • c#实现服务器性能监控并发送邮件保存日志
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • windows/windows 7/windows 8 下打开查看、修改及保存超大(GB级)文本文件及其它类型文件的工具-PilotEdit
  • vi编辑了一个文件,不想保存,想打开另一个文件,:o 1.c 。vi提示尚未保存,可用!执行。这里的!应该是加在哪里呢?
  • 请问我登陆FTP后用get命令保存的文件放在什么地方,如何更改它的默认保存路径?
  • GUI问题:如何使用文件选择对话框保存文本文件,图像文件??
  • 保存java.sh文件时,多出一个java.sh~文件
  • vi一个文件后不知怎么保存?
  • JFileChooser如何保存一个文件?具体来说:如何得到键入textField的文件名?
  • 走过路过的都看一看,文件保存
  • 如何保存.XML的网页文件?
  • 关于将文件保存到数据库的问题?
  • ubuntu下的.cpp,.h文件没法保存中文(从xp下面复制过来的源文件)
  • Eclipse 3.2 不能保存文件问题。急急急
  • windows/windows 7/windows 8 下打开查看、修改及保存超大(GB级)文本文件及其它类型文件的工具-PilotEdit iis7站长之家
  • shell中用vi打开一个文件并自动保存
  • linux中标准c如何将XImage对象数据保存到bmp或jpg文件
  • vim编辑一个文件,修改,保存,然后我后悔了,咋办
  • vi 不能保存文件 问题
  • 请问如何用shell脚本在文件中提取出任意位置的字符串并保存到另外一个文件中。
  • 用jdk编译Java能不能让编译生成的.class文件自动保存到一个文件夹下?
  • nginx中文件下载指定保存文件名的配置方法
  • 现在csdn的网页都是.xml文件,我的电脑在脱机后无法对保存的文件脱机浏览,太不方便了,怎么办?
  • 通过docker commit命令保存对docker容器的修改
  • 各位大虾,vi怎么进入命令模式,并且保存退出/不保存退出?急死我了
  • Molliza 浏览器中书签保存的网址,保存在哪里?
  • 请问linux进程的哪些信息保存在内核里?哪些信息又保存在进程空间里?谢谢
  • 删除重复的记录,并保存第一条记录或保存最后一条记录
  • 自动保存插件 Notepad++ AutoSave
  • Android 实现永久保存数据的方法详解
  • 怎样保存linux命令行?急,马上揭贴
  • 关于Applet的图形处理后,如何保存?急急!
  • 关于Applet的图形处理后,如何保存?急急!


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3