C#以流方式把DataGridView数据导出Excel!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#以流方式把DataGridView数据导出Excel!相关的知识,希望对你有一定的参考价值。

有以下代码用以DataGridView导出Excel,导出2003的格式完全没问题,现在想把 dlg.Filter = "Execl files (*.xls)|*.xls"; 改成 dlg.Filter = "Excel 2003|*.xls|Excel 2007|*.xlsx";想法是可以选择直接导出2003还是2007格式,但是选择保存为.xlsx格式就打不开,提示扩展名问题,Excel2007打不开这文件,请教各位大侠有没有办法改改?或者其他导出方法也行,关键速度要快(暂时不想用那种逐行导出的代码,太慢了),谢谢大家先!

public void DataGridViewToExcel(DataGridView dgv)

SaveFileDialog dlg = new SaveFileDialog();
dlg.Filter = "Execl files (*.xls)|*.xls";
//dlg.Filter = "Excel 2003|*.xls|Excel 2007|*.xlsx";
dlg.CheckFileExists = false;
dlg.CheckPathExists = false;
dlg.FilterIndex = 0;
dlg.RestoreDirectory = true;
dlg.CreatePrompt = false;
dlg.Title = "保存为Excel文件";

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

Stream myStream;
myStream = dlg.OpenFile();
StreamWriter sw = new StreamWriter(myStream, System.Text.Encoding.GetEncoding(-0));
string columnTitle = "";
try

//写入列标题
for (int i = 0; i < dgv.ColumnCount; i++)

if (i > 0)

columnTitle += "\t";

columnTitle += dgv.Columns[i].HeaderText;

sw.WriteLine(columnTitle);

//写入列内容
for (int j = 0; j < dgv.Rows.Count; j++)

string columnValue = "";
for (int k = 0; k < dgv.Columns.Count; k++)

if (k > 0)

columnValue += "\t";

if (dgv.Rows[j].Cells[k].Value == null)
columnValue += "";
else
columnValue += dgv.Rows[j].Cells[k].Value.ToString().Trim();

sw.WriteLine(columnValue);

sw.Close();
myStream.Close();
MessageBox.Show("数据导出成功!", "提示", MessageBoxButtons.OK);

catch (Exception e)

MessageBox.Show(e.ToString());

finally

sw.Close();
myStream.Close();


C#导出Excel的函数(可根据实际需要进行相应修改)

//导出Excel的方法
private void ExportExcel()

DataSet ds=dtsSelect;//数据源
if(ds==null) return;

string saveFileName="";
bool fileSaved=false;
SaveFileDialog saveDialog=new SaveFileDialog();
saveDialog.DefaultExt ="xls";
saveDialog.Filter="Excel文件|*.xls";
saveDialog.FileName ="Sheet1";
saveDialog.ShowDialog();
saveFileName=saveDialog.FileName;
if(saveFileName.IndexOf(":")<0) return; //被点了取消

Excel.Application xlApp=new Excel.Application();

if(xlApp==null)

MessageBox.Show("无法创建Excel对象,可能您的机子未安装Excel");
return;


Excel.Workbooks workbooks=xlApp.Workbooks;
Excel.Workbook workbook=workbooks.Add(Excel.XlWBATemplate.xlWBATWorksheet);
Excel.Worksheet worksheet=(Excel.Worksheet)workbook.Worksheets[1];//取得sheet1
//写入字段
for(int i=0;i<ds.Tables[0].Columns.Count;i++)

worksheet.Cells[1,i+1]=ds.Tables[0].Columns[i].ColumnName;

//写入数值

for(int r=0;r<ds.Tables[0].Rows.Count;r++)

for(int i=0;i<ds.Tables[0].Columns.Count;i++)

worksheet.Cells[r+2,i+1]=ds.Tables[0].Rows[r][i];

System.Windows.Forms.Application.DoEvents();

worksheet.Columns.EntireColumn.AutoFit();//列宽自适应。
if(cmbxType.Text!="Notification")

Excel.Range rg=worksheet.get_Range(worksheet.Cells[2,2],worksheet.Cells[ds.Tables[0].Rows.Count+1,2]);
rg.NumberFormat="00000000";

if(saveFileName!="")

try

workbook.Saved =true;
workbook.SaveCopyAs(saveFileName);
fileSaved=true;

catch(Exception ex)

fileSaved=false;
MessageBox.Show("导出文件时出错,文件可能正被打开!\n"+ex.Message);


else

fileSaved=false;

xlApp.Quit();
GC.Collect();//强行销毁
if(fileSaved && System.IO.File.Exists(saveFileName)) System.Diagnostics.Process.Start(saveFileName); //打开EXCEL
参考技术A 其实你导出的文件,其实是一个标准的文本文件(相当于 CSV 文件),根本就不是 EXCEL 文档。你只不过把扩展名改成了 *.xls 冒充 EXCEL 文件而已,本质上就是文本文件,用记事本打开的那种!

在 Excel 2003 比较宽宏大量,允许你这种龌龊的冒充行为而已(呵呵),所以在 2003 中你能打开,到了 2007 后不在允许赤裸裸的、龌龊冒充行为(哈哈),所以你的“导出”立即穿帮了。。。。

解决办法:
微软在 Office 2007 版本开始使用 OpenXML 格式了。何为 OpenXML ?其实就是一种开放标准的 XML 文件,你导出 Excel 2007 文件,只要遵守 OpenXML 格式写入文本就可以了。
另外:OpenXML 还涉及到 ZIP 压缩,幸好 .NET 自带 ZIP 压缩类,你可以上网搜一下代码,很多。

OpenXML 文件格式参考文档:
http://www.360doc.com/content/11/0324/14/1244775_104184482.shtml本回答被提问者采纳
参考技术B 肯定有办法,但真懒得自己去弄,我一般用控件直接导,netadvantage有直接导出excel的控件,支持2007版本,推荐试一下!

c# winform DataGridView导出数据到Excel中,可以导出当前页和全部数据

准备工作就是可以分页的DataGridView,和两个按钮,一个用来导出当前页数据到Excel,一个用来导出全部数据到Excel

没有使用SaveFileDialog,但却可以弹出保存对话框来

先做导出当前页数据到Excel的

DataGridView命名为dataGridView1

技术图片
 1 //按下导出按钮  
 2 private void button7_Click(object sender, EventArgs e)  
 3   
 4     print(dataGridView1);  
 5   
 6 public void print(DataGridView dataGridView1)  
 7   
 8     //导出到execl  
 9     try  
10       
11         //没有数据的话就不往下执行  
12         if (dataGridView1.Rows.Count == 0)  
13             return;  
14         //实例化一个Excel.Application对象  
15         Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();  
16   
17         //让后台执行设置为不可见,为true的话会看到打开一个Excel,然后数据在往里写  
18         excel.Visible = false;  
19                   
20         //新增加一个工作簿,Workbook是直接保存,不会弹出保存对话框,加上Application会弹出保存对话框,值为false会报错  
21     excel.Application.Workbooks.Add(true);                
22         //生成Excel中列头名称  
23         for (int i = 0; i < dataGridView1.Columns.Count; i++)  
24           
25             excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;  
26           
27         //把DataGridView当前页的数据保存在Excel中  
28         for (int i = 0; i < dataGridView1.Rows.Count - 1; i++)  
29           
30             for (int j = 0; j < dataGridView1.Columns.Count; j++)  
31               
32                 if (dataGridView1[j, i].ValueType == typeof(string))  
33                   
34                     excel.Cells[i + 2, j + 1] = "" + dataGridView1[j, i].Value.ToString();  
35                   
36                 else  
37                   
38                     excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString();  
39                   
40               
41           
42   
43         //设置禁止弹出保存和覆盖的询问提示框  
44         excel.DisplayAlerts = false;  
45         excel.AlertBeforeOverwriting = false;  
46   
47         //保存工作簿  
48         excel.Application.Workbooks.Add(true).Save();  
49         //保存excel文件  
50         excel.Save("D:" + "\\KKHMD.xls");  
51                       
52         //确保Excel进程关闭  
53         excel.Quit();  
54         excel = null;  
55   
56       
57     catch (Exception ex)  
58       
59         MessageBox.Show(ex.Message, "错误提示");  
60       
61   
View Code

导出从数据库中查询到的所有的数据到Excel中

技术图片
 1 #region 导出全部数据到Excel中,可弹出保存对话框,但没用SaveFileDialog  
 2   
 3 public void printAll(System.Data.DataTable dt)  
 4   
 5     //导出到execl  
 6     try  
 7       
 8         //没有数据的话就不往下执行  
 9         if (dt.Rows.Count == 0)  
10             return;  
11         //实例化一个Excel.Application对象  
12         Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();  
13   
14         //新增加一个工作簿,Workbook是直接保存,不会弹出保存对话框,加上Application会弹出保存对话框,值为false会报错  
15         excel.Application.Workbooks.Add(true);  
16   
17         //让后台执行设置为不可见,为true的话会看到打开一个Excel,然后数据在往里写  
18         excel.Visible = false;  
19         //生成Excel中列头名称  
20         for (int i = 0; i < dt.Columns.Count; i++)  
21           
22             excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;//输出DataGridView列头名  
23           
24   
25         //把DataGridView当前页的数据保存在Excel中  
26         if (dt.Rows.Count > 0)  
27           
28             for (int i = 0; i < dt.Rows.Count; i++)//控制Excel中行,上下的距离,就是可以到Excel最下的行数,比数据长了报错,比数据短了会显示不完  
29               
30                 for (int j = 0; j < dt.Columns.Count; j++)//控制Excel中列,左右的距离,就是可以到Excel最右的列数,比数据长了报错,比数据短了会显示不完  
31                   
32                     string str = dt.Rows[i][j].ToString();  
33                     excel.Cells[i + 2, j + 1] = "" + str;//i控制行,从Excel中第2行开始输出第一行数据,j控制列,从Excel中第1列输出第1列数据,"‘" +是以string形式保存,所以遇到数字不会转成16进制  
34                   
35               
36           
37         //设置禁止弹出保存和覆盖的询问提示框  
38         excel.DisplayAlerts = false;  
39         excel.AlertBeforeOverwriting = false;  
40   
41         //保存工作簿,值为false会报错  
42         excel.Application.Workbooks.Add(true).Save();  
43         //保存excel文件  
44         excel.Save("D:" + "\\KKHMD.xls");  
45   
46         //确保Excel进程关闭  
47         excel.Quit();  
48         excel = null;  
49   
50       
51     catch (Exception ex)  
52       
53         MessageBox.Show(ex.Message, "错误提示");  
54       
55   
56 private void button1_Click(object sender, EventArgs e)  
57   
58     printAll(dt);  
59   
60  
61 #endregion  
View Code

这不是最好的版本,无论是功能上还是效率上,至少没用SaveFileDialog的话,控制不到取消保存按钮,一旦点击了取消保存,则软件重起之前一直都不能再使用导出功能,只能是手动杀掉进程中的Excel.exe,进程中的Excel.exe也是没有在程序里进行关闭的,所以是使用一次导出功能,就会在进程中多生成一次Excel.exe

以上是关于C#以流方式把DataGridView数据导出Excel!的主要内容,如果未能解决你的问题,请参考以下文章

c# 怎么把dataGridView的数据 用Excel导出! 详细点啊

C#把DataGridView的数据导出为WPS的Excel需要引用啥组件

C# 怎么把从数据库查询出来的东西累加到dataGridView里面去

c# winform DataGridView导出数据到Excel中,可以导出当前页和全部数据

C# 中的 DataGridView 导出器

C#中把datagridview中显示的数据导出到excel中