从DataGridView导出Excel的两种情况,不多说,直接记录代码(新建类,直接引用传入参数)。

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Windows.Forms;

using System.IO;

using System.Data;

namespace cnblogs

{

public static class LoadExcel

{

//从DataGridView中导出Excel,若s为null则直接导出DataGridView中的内容

public static void DataToExcel(DataGridView m_DataView,string s)

{

SaveFileDialog kk = new SaveFileDialog();

kk.Title = "保存EXECL文件";

kk.Filter = "EXECL文件(*.xls) |*.xls |所有文件(*.*) |*.*";

kk.FilterIndex = 1;

if (kk.ShowDialog() == DialogResult.OK)

{

string FileName = kk.FileName;// +".xls";

if (File.Exists(FileName))

File.Delete(FileName);

FileStream objFileStream;

StreamWriter objStreamWriter;

string strLine = "";

objFileStream = new FileStream(FileName, FileMode.OpenOrCreate, FileAccess.Write);

objStreamWriter = new StreamWriter(objFileStream, System.Text.Encoding.Unicode);

objStreamWriter.WriteLine(s); //统计结果信息

for (int i = 0; i < m_DataView.Columns.Count; i++)

{

if (m_DataView.Columns[i].Visible == true)

{

strLine = strLine + m_DataView.Columns[i].HeaderText.ToString() + Convert.ToChar(9);

}

}

objStreamWriter.WriteLine(strLine);

strLine = "";

for (int i = 0; i < m_DataView.Rows.Count; i++)

{

if (m_DataView.Columns[0].Visible == true)

{

if (m_DataView.Rows[i].Cells[0].Value == null)

strLine = strLine + " " + Convert.ToChar(9);

else

strLine = strLine + m_DataView.Rows[i].Cells[0].Value.ToString() + Convert.ToChar(9);

}

for (int j = 1; j < m_DataView.Columns.Count; j++)

{

if (m_DataView.Columns[j].Visible == true)

{

if (m_DataView.Rows[i].Cells[j].Value == null)

strLine = strLine + " " + Convert.ToChar(9);

else

{

string rowstr = "";

rowstr = m_DataView.Rows[i].Cells[j].Value.ToString();

if (rowstr.IndexOf("\r\n") > 0)

rowstr = rowstr.Replace("\r\n", " ");

if (rowstr.IndexOf("\t") > 0)

rowstr = rowstr.Replace("\t", " ");

strLine = strLine + rowstr + Convert.ToChar(9);

}

}

}

objStreamWriter.WriteLine(strLine);

strLine = "";

}

objStreamWriter.Close();

objFileStream.Close();

MessageBox.Show("导出成功!");

}

}

//用DataGridView绑定的DataTable为参数,导出Excel

public static void DataToExcel(DataTable m_DataTable)

{

SaveFileDialog kk = new SaveFileDialog();

kk.Title = "保存EXECL文件";

kk.Filter = "EXECL文件(*.xls) |*.xls |所有文件(*.*) |*.*";

kk.FilterIndex = 1;

if (kk.ShowDialog() == DialogResult.OK)

{

string FileName = kk.FileName + ".xls";

if (File.Exists(FileName))

File.Delete(FileName);

FileStream objFileStream;

StreamWriter objStreamWriter;

string strLine = "";

objFileStream = new FileStream(FileName, FileMode.OpenOrCreate, FileAccess.Write);

objStreamWriter = new StreamWriter(objFileStream, System.Text.Encoding.Unicode);

for (int i = 0; i < m_DataTable.Columns.Count; i++)

{

strLine = strLine + m_DataTable.Columns[i].Caption.ToString() + Convert.ToChar(9);

}

objStreamWriter.WriteLine(strLine);

strLine = "";

for (int i = 0; i < m_DataTable.Rows.Count; i++)

{

for (int j = 0; j < m_DataTable.Columns.Count; j++)

{

if (m_DataTable.Rows[i].ItemArray[j] == null)

strLine = strLine + " " + Convert.ToChar(9);

else

{

string rowstr = "";

rowstr = m_DataTable.Rows[i].ItemArray[j].ToString();

if (rowstr.IndexOf("\r\n") > 0)

rowstr = rowstr.Replace("\r\n", " ");

if (rowstr.IndexOf("\t") > 0)

rowstr = rowstr.Replace("\t", " ");

strLine = strLine + rowstr + Convert.ToChar(9);

}

}

objStreamWriter.WriteLine(strLine);

strLine = "";

}

objStreamWriter.Close();

objFileStream.Close();

}

}

}

}

从DataGridView导出Excel的更多相关文章

  1. c# datagridview导出Excel文件 问题

    今天vs2010c#开发做datagridview导出Excel文件时,发现一个问题,和大家探讨一下: 第一种方式:写流的方式 private void button_Excel_Click(obje ...

  2. 一个通用的DataGridView导出Excel扩展方法(支持列数据格式化)

    假如数据库表中某个字段存放的值“1”和“0”分别代表“是”和“否”,要在DataGridView中显示“是”和“否”,一般用两种方法,一种是在sql中直接判断获取,另一种是在DataGridView的 ...

  3. C# DataGridView 导出 Excel(根据Excel版本显示选择不同后缀格式xls或xlsx)

    /// <summary> /// DataGridView导出至Excel,解决问题:打开Excel文件格式与扩展名指定格式不一致 /// </summary> /// &l ...

  4. DataGridView 导出Excel (封装)

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

  5. DataGridView导出Excel

    将DataGridView里面的数据,导出到表格里面去. 首先,需要添加三个引用 直接在解决方案里,右键添加引用,找到路径即可.然后再把这三个文件复制到项目的根目录下. 然后定义导出表格的函数: pu ...

  6. C# DataGridView导出Excel

    using Microsoft.Office.Interop.Excel;                using Excel=Microsoft.Office.Interop.Excel; //这 ...

  7. winform datagridview 导出excel

    using System;using System.Collections.Generic;using System.Text;using System.IO;using Microsoft.Offi ...

  8. 在窗体中把DataGridView中的数据导出Excel

    //DataGridView导出Excel private void bt_Excl_Click(object sender, EventArgs e) { SaveFileDialog saveFi ...

  9. Winform 导出Excel

    private void 导出excelToolStripMenuItem_Click(object sender, EventArgs e) { ) { var saveFileDialog1 = ...

随机推荐

  1. 编译安装 Zend Opcache 缓存Opcache,加速 PHP

    Optimizer+ 是 Zend 开发的闭源但可以免费使用的 PHP 优化加速组件,是第一个也是最快的 opcode 缓存工具.现在,Zend 科技公司将 Optimizer+ 在 PHP Lice ...

  2. JQuery EasyUI DataGrid获取当前行或选中行

    1.获取当前选中行,如果没有选中行,则返回 null var row = $('#gridID').datagrid('getSelected'); 2.获取当前所有选中行数据,返回元素记录的数组数据 ...

  3. 如何查看oracle 的package源码

    select text from dba_source t where t.TYPE = 'PACKAGE BODY' and name ='EMR_RECORD_INPUT' order by li ...

  4. redis该如何分区-译文(原创)

    写在最前,最近一直在研究redis的使用,包括redis应用场景.性能优化.可行性.这是看到redis官网中一个链接,主要是讲解redis数据分区的,既然是官方推荐的,那我就翻译一下,与大家共享. P ...

  5. 垂直居中display:table;

    父级元素 display:table: 子元素 display:table-cell:vertical-align:middle:

  6. Qt界面中嵌入其他exe程序的界面,使用Qt5

    下面用一个小例子来演示如何在Qt的界面中嵌入其他exe程序的界面,最终效果如下图所示.本文参考了 http://blog.csdn.net/jiaoyaziyang/article/details/4 ...

  7. Hibernate参数一览表

    参考文章地址:http://www.blogjava.net/i369/articles/194855.html Hibernate 参数设置一览表 属性名 用途 hibernate.dialect ...

  8. javascript escape()函数和unescape()函数

    javascript escape()函数和unescape()函数 escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串. 语法: escape(string) stri ...

  9. C Primer Plus_第6章_循环_编程练习

    1.题略 #include int main(void) { int i; char ch[26]; for (i = 97; i <= (97+25); i++) { ch[i-97] = i ...

  10. kNN算法python实现和简单数字识别

    kNN算法 算法优缺点: 优点:精度高.对异常值不敏感.无输入数据假定 缺点:时间复杂度和空间复杂度都很高 适用数据范围:数值型和标称型 算法的思路: KNN算法(全称K最近邻算法),算法的思想很简单 ...