方法一:循环DataTable单元格内容拼接字符串,利用StreamWriter的Write方法将字符串写入Excel文件中

这种方法很实现很简单。拼接字符串时,每个单元格之间添加'\t'(表示一个占位符,相当于Tab键),每行之间添加"\r\n"(表示换行)。

但是这种方法不能设置Excel单元格样式

1、定义一个方法GetSavePath(),利用SaveFileDialog控件选择Excel文件要保存的路径。

private string GetSavePath()
{
    using (SaveFileDialog savePath = new SaveFileDialog())
    {
        savePath.Title = "选择要保存的路径和文件名";
        savePath.Filter = "Excel 97-2003|*.xls";
        savePath.RestoreDirectory = true; //是否记录上次选择的路径
        savePath.FileName = "导出的表格";
        if (savePath.ShowDialog() == DialogResult.OK)
        {
            return savePath.FileName; //返回Excel文件的保存路径和名字
        }
        return "Cancel";
    }
}

2、定义一个方法GetSWstr(),将DataTable内容转换成字符串。

private string GetSWstr(DataTable table2)
{
    StringBuilder strHead = new StringBuilder ();
    //先添加每列标题
    ; i < table2.Columns.Count; i++)
    {
        strHead.Append(table2.Columns[i].Caption.Trim() + '\t');
    }
    strHead.Append("\r\n");
    //再依次添加每行内容
    ; i < table2.Rows.Count; i++)
    {
        ; j < table2.Columns.Count; j++)
        {
            strHead.Append(table2.Rows[i][j].ToString().Trim() + '\t');
        }
        strHead.Append("\r\n");
    }
    return strHead.ToString();
}

3、定义一个方法 WriteToExcel(),将内容写入Excel文件

public string WriteToExcel(String str, string filePath)
{
    try
    {
        using (StreamWriter sw = new StreamWriter(filePath, false, System.Text.Encoding.Default)) //写入流
        {
            sw.Write(str);
        }
        return "导出Execl成功!";
    }
    catch (Exception ex)
    {
        return "导出Execl失败!原因:" + ex.Message;
    }
}

4、调用WriteToExcel

WriteToExcel(GetSWstr(table), GetSavePath());

方法二:利用COM组件实现Excel操作,可以设置Excel格式

这种操作也很简单,在定义好excel对象后,可以通过 excel.Cells[i, j]=? 对某一个单元格赋值。

也可以通过 range = excel.Range[excel.Cells[i, 1], excel.Cells[i, 3]]; 获取一个单元格区域,然后设置range的属性就可以设置单元格样式或值

range.MergeCells = true;  //合并单元格

range.Value = "标题";

Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
Microsoft.Office.Interop.Excel.Workbook book = excel.Workbooks.Add(true);
Microsoft.Office.Interop.Excel.Range range = null;
try
{
    //第一行的第一列到第六列
    range = excel.Range[excel.Cells[, ], excel.Cells[, ]];
    range.MergeCells = true; ///合并单元格
    range.Font.Bold = true; //黑体
    range.Font.Size = ; //20号字体
    range.HorizontalAlignment = XlHAlign.xlHAlignCenter; //水平居中
    range.Value = "产品工序分解表";   //合并单元格的值
}
catch(Exception ex)
{
    return "导出失败!错误原因:" + ex.Message;
}
finally
{
    book = null;
    range = null;
    GC.Collect();
    GC.WaitForPendingFinalizers();
    excel.Quit();
    excel = null;
}

将DataTable内容导出到Excel表格的两种方法的更多相关文章

  1. .NET环境下导出Excel表格的两种方式和导入两种类型的Excel表格

    一.导出Excel表格的两种方式,其中两种方式指的是导出XML数据类型的Excel(即保存的时候可以只需要修改扩展名为.xls)和真正的Excel这两种. using System; using Sy ...

  2. js如何动态创建表格(两种方法)

    js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...

  3. 用easyui实现查询条件的后端传递并自动刷新表格的两种方法

    用easyui实现查询条件的后端传递并自动刷新表格的两种方法 搜索框如下: 通过datagrid的load方法直接传递参数并自动刷新表格 通过ajax的post函数传递参数并通过loadData方法将 ...

  4. .NET CORE 2.1 导出excel文件的两种方法

    最近在做 MVC 项目的时候遇到项目的导出,下面总结下两种导出到excel 的方法 第一种方法: 将文件写到本地,然后返回这个File 或者返回这个 File 的绝对地址  其中  _hostingE ...

  5. LayUI使用弹窗重载父级数据表格的两种方法

    参考LayUI官方文档,在子窗口中重载父级数据表格找到以下两种方法: 1.子窗口中重载:在子窗口中直接调用父级talbe的reload方法. $("body").on(" ...

  6. C#将数据集DataSet中的数据导出到EXCEL文件的几种方法

    using System; using System.Collections.Generic; using System.Text; using System.Data; using System.W ...

  7. Java导出Excel文件的两种方法

    将数据以Excel表格的形式导出:首先下载poi的jar包,导入项目中,或者使用maven仓库管理,在pom文件添加:<dependency>    <groupId>org. ...

  8. mysql导出csv/excel文件的几种方法,mysql的load导入csv数据

    方法一 php教程用mysql的命令和shell select * into outfile './bestlovesky.xls' from bestlovesky where 1 order by ...

  9. delphi 导出到excel的第1种方法

    第一种方法delphi 快速导出excel uses ComObj,clipbrd; function ToExcel(sfilename:string; ADOQuery:TADOQuery):bo ...

随机推荐

  1. Git Config(转)

    一.Git已经在你的系统中了,你会做一些事情来客户化你的Git环境.   你只需要做这些设置一次:即使你升级了,他们也会绑定到你的环境中.你也可以在任何时刻通过运行命令来重新更改这些设置.      ...

  2. Android采访开发——2.通用Android基础笔试题

    注意finddreams博客: http://blog.csdn.net/finddreams/article/details/44219231 正值跳槽的热季.整理一下Android面试中最常考的笔 ...

  3. 通过管道进行线程间通信:字节流。字符流的用法及API类似

    管道流(PipedStream)可以用于不同线程间直接传送数据.一个线程发送数据到输出管道,另一个线程从输入管道中读取数据.通过使用管道,实现不同线程间的通信,而无须借助于类似临时文件之类的东西. p ...

  4. 选择一个利于SEO的空间

    大家好.今天蜗牛将给大家分享怎么选择一个利于SEO的站点空间. 一.什么是站点空间? 站点空间,是用来存你的站点的HTML,.图片.文件等的一个远程硬盘空间(就像你的电脑里面的空间一回事儿).依据不同 ...

  5. 十天学Linux内核之第十天---总结篇(kconfig和Makefile & 讲不出再见)

    原文:十天学Linux内核之第十天---总结篇(kconfig和Makefile & 讲不出再见) 非常开心能够和大家一起分享这些,让我受益匪浅,感激之情也溢于言表,,code monkey的 ...

  6. printf交替使用

    今天附带printf一些替代实现. 转载请注明出处:http://blog.csdn.net/u010484477谢谢^_^ 我们总是用printf做各种输出语句: printf("%d&q ...

  7. 大约SQL/NoSQL数据库搜索/思考查询

    转载请注明出处:jiq•钦's technical Blog Hbase特征: 近期在学习Hbase.Hbase基于行健是建立了索引的,查询速度会很快,全然实时. 可是Hbase要基于行健之外的字段进 ...

  8. c语言获取符号位整数和浮点

    1. 为什么你应该得到的签位 非常多的时间,我们需要推断的数目值正和负,做了相应的逻辑处理.完成这一要求条件推断语句可以很好. 有时会出现以下情况, if (x > 0) { x = x - 1 ...

  9. 【转】HTTP协议两种提交参数的方式Form-data和raw

    原文:http://www.cnblogs.com/zhangfei/p/5099036.html HTTP协议的接口测试中,使用到最多的就是GET请求与POST请求,其中POST请求有FORM参数提 ...

  10. Postman 是一个非常棒的Chrome扩展,提供功能强大的API & HTTP 请求调试

    Postman 是一个非常棒的Chrome扩展,提供功能强大的API & HTTP 请求调试   需要FQ才能安装,使用时应该不用FQ了,除非使用postman的历史记录功能:   非常棒的C ...