C#的winform窗体引用 Microsoft.Office.Interop.Excel向Excel传递数据时出现ArgumentException错误,求解

部分代码:if(dgv_View.Rows.Count==0)return;//创建Excel对象Microsoft.Office.Interop.Excel.Appli... 部分代码:
if (dgv_View.Rows.Count == 0)
return;
//创建Excel对象
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
显示异常代码位置:excel.Application.Workbooks.Add(true); //在excel中添加一个工作簿
excel.Visible = true; //设置excel显示
部分异常详情:
未处理 System.ArgumentException
Message="值不在预期的范围内。"
Source="Microsoft.Office.Interop.Excel"
StackTrace:
在 Microsoft.Office.Interop.Excel.Workbooks.Add(Object Template)
在 fighting.Other.Other_Excel.Excel() 位置 D:\fighting\fighting\Other_Excel.cs:行号 32
在 fighting.Other.Other_Excel.tbn_Excel_Click(Object sender, EventArgs e) 位置 D:\fighting\fighting\Other_Excel.cs:行号 134
在 System.Windows.Forms.Control.OnClick(EventArgs e)
在 System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
在 System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
在 System.Windows.Forms.Control.WndProc(Message& m)
在 System.Windows.Forms.ButtonBase.WndProc(Message& m)
展开
 我来答
shuibiyy
推荐于2016-01-25 · TA获得超过1724个赞
知道小有建树答主
回答量:446
采纳率:100%
帮助的人:143万
展开全部
直接给你例子参考
#region 写入Excel文档
/// <summary>
/// 写入Excel文档
/// </summary>
/// <param name="Path">文件名称</param>
/// <param name="ds2Excel">被导出的数据集</param>

public static void SaveFP2toExcel(string Path, DataSet ds2Excel)
{
try
{
//创建Excel应用程序

Excel.Application xApp = new Excel.ApplicationClass();
if (xApp == null)
{
MessageBox.Show("错误:Excel不能打开!");
return;
}
object objOpt = Missing.Value;
Excel.Workbook xBook = xApp.Workbooks.Add(true);//添加新工作簿
Excel.Sheets xSheets = xBook.Sheets;
Excel._Worksheet xSheet = null;
//
//创建空的sheet
//
xSheet = (Excel._Worksheet)(xBook.Sheets.Add(objOpt, objOpt, objOpt, objOpt));
xSheet.Cells.NumberFormatLocal = "@";
if (xSheet == null)
{
MessageBox.Show("错误:工作表为空!");
return;
}
//写数据集表头
for (int k = 0; k < ds2Excel.Tables[0].Columns.Count; k++)
xSheet.Cells[1, k + 1] = ds2Excel.Tables[0].Columns[k].ColumnName.ToString().Trim();
//写数据集数据
for (int i = 0; i < ds2Excel.Tables[0].Rows.Count; i++)
{
for (int j = 0; j < ds2Excel.Tables[0].Columns.Count; j++)
xSheet.Cells[i + 2, j + 1] = ds2Excel.Tables[0].Rows[i][j].ToString();
}
//保存文件
xBook.Saved = true;
xBook.SaveCopyAs(Path);

//显示文件
xApp.Visible = true;
//
//释放资源
//
Marshal.ReleaseComObject(xSheet);
xSheet = null;
Marshal.ReleaseComObject(xSheets);
xSheets = null;

Marshal.ReleaseComObject(xBook);
xBook = null;
xApp.Quit();
Marshal.ReleaseComObject(xApp);
xApp = null;
GC.Collect();//强行销毁
MessageBox.Show("导出成功");

}
catch (Exception ex)
{
MessageBox.Show("写入Excel发生错误:" + ex.Message);
}
}
#endregion
178******56
2014-09-09 · TA获得超过124个赞
知道小有建树答主
回答量:592
采纳率:0%
帮助的人:677万
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式