C#为问题:将datagridview数据导出到excel出现---异常来自 hresult 0x800a03ec,求大师解决! 10

代码如下:本人是通过textbox控件将数据添加到datagridview中,然后通过button导出到Excel中出现问题!privatevoidbutton1_Cli... 代码如下:本人是通过textbox控件将数据添加到datagridview中,然后通过button导出到Excel中出现问题!

private void button1_Click(object sender, EventArgs e)
{
print(dataGridView1);
}

public void print(DataGridView dataGridView1)
{
//导出到execl
try
{
//没有数据的话就不往下执行
if (dataGridView1.Rows.Count == 0)
return;
//实例化一个Excel.Application对象
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();

//让后台执行设置为不可见,为true的话会看到打开一个Excel,然后数据在往里写
excel.Visible = false;

//新增加一个工作簿,Workbook是直接保存,不会弹出保存对话框,加上Application会弹出保存对话框,值为false会报错
excel.Application.Workbooks.Add(true);
//生成Excel中列头名称
for (int i = 0; i < dataGridView1.Columns.Count; i++)
{
excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;
}
//把DataGridView当前页的数据保存在Excel中
for (int i = 0; i < dataGridView1.Rows.Count - 1; i++)
{
for (int j = 0; j < dataGridView1.Columns.Count; j++)
{
if (dataGridView1[j, i].ValueType == typeof(string))
{
excel.Cells[i + 2, j + 1] = "'" + dataGridView1[j, i].Value.ToString();
}
else
{
excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString();
}
}
}

//设置禁止弹出保存和覆盖的询问提示框
excel.DisplayAlerts = false;
excel.AlertBeforeOverwriting = false;

//保存工作簿
excel.Application.Workbooks.Add(true).Save();
//保存excel文件
excel.Save("D:" + "\\KKHMD.xls");

//确保Excel进程关闭
excel.Quit();
excel = null;

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

有没有更好的代码?救助。。。
展开
 我来答
syht2000
高粉答主

2014-04-28 · 关注我不会让你失望
知道大有可为答主
回答量:3万
采纳率:79%
帮助的人:1.4亿
展开全部
没明白你想问什么,你的标题与内容是两码事,如果是取消的问题,SaveFileDialog应该这样用
private void button1_Click(object sender, EventArgs e)
{
//saveFileDialog的属性自己设置一下
if (this.saveFileDialog.ShowDialog() == DialogResult.OK)
{
print(dataGridView1,saveFileDialog.FileName);

}
}

public void print(DataGridView dataGridView1,string filename)

{
//前面都一样
//保存excel文件
excel.Save(filename);
}
追问

我就是用button直接保存datagridview里的数据,此数据不是通过数据库呈现的,点击button,出现异常---异常来自 hresult 0x800a03ec

也生成了EXCEl文件,但不是此路径"D:" + "\\KKHMD.xls",名称为sheet2.xls.

等不到的落幕
2014-04-28 · TA获得超过312个赞
知道小有建树答主
回答量:137
采纳率:100%
帮助的人:104万
展开全部
在finally里面添加关闭excel能好使么?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式