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();
//导出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
导出从数据库中查询到的所有的数据到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
这不是最好的版本,无论是功能上还是效率上,至少没用SaveFileDialog的话,控制不到取消保存按钮,一旦点击了取消保存,则软件重起之前一直都不能再使用导出功能,只能是手动杀掉进程中的Excel.exe,进程中的Excel.exe也是没有在程序里进行关闭的,所以是使用一次导出功能,就会在进程中多生成一次Excel.exe
以上是关于C#以流方式把DataGridView数据导出Excel!的主要内容,如果未能解决你的问题,请参考以下文章
c# 怎么把dataGridView的数据 用Excel导出! 详细点啊
C#把DataGridView的数据导出为WPS的Excel需要引用啥组件
C# 怎么把从数据库查询出来的东西累加到dataGridView里面去