无法设置活动 Excel sheet C#
Unable to set active Excel sheet C#
我 运行 一些 C# 代码作为脚本组件的一部分 运行 在我的 SSIS 包中。在我的 SSIS 包的下一步中导入文件之前,我试图打开一个 Excel 文件并更改 sheet 的名称。我在尝试初始化 "oSheet" 的行中遇到错误。
错误说明:“错误 1 找不到编译动态表达式所需的一种或多种类型。是否缺少引用?C:\Temp\Vsta\SSIS_ST110\VstaTP9LtckEMUWOXYp4Zy3YpQ\Vstau3xOw__Ey1kaOxXFoq0ff8g\ScriptMain.cs 107 26 ST_005c649f34584ed6873a7fde862ab2c9
“
我有一段时间没有使用 C#,希望有人能给我指出正确的方向。提前致谢!
代码:
public void Main()
{
String s = (String)Dts.Variables["FilePath"].Value;
String FileName = s.Substring(45,s.Length - 45); //45 = hardcoded value for known index of the start of the file name
MessageBox.Show(FileName);
Excel.Application oXL;
Excel._Workbook oWB;
Excel._Worksheet oSheet;
Excel.Range oRng;
try
{
oXL = new Microsoft.Office.Interop.Excel.Application();
oXL.Visible = false;
oWB = (Excel.Workbook)oXL.Workbooks.Open(s);
oSheet = (Excel._Worksheet)oWB.ActiveSheet;
//oSheet = (Excel._Worksheet)oXL.ActiveSheet;
//oSheet = (Excel._Worksheet)oWB.Worksheets.Item(0);
//oSheet = (Excel._Worksheet)oXL.Worksheets[FileName];
oSheet.Name = "NLTWNH";
oWB.Close(s);
}
catch (Exception ex)
{
//do nothing
}
Dts.TaskResult = (int)ScriptResults.Success;
}
首先,添加对 Microsoft Excel Interop DLL 的引用。您可以通过右键单击解决方案资源管理器中的引用文件夹来执行此操作。然后点击添加引用。
单击 "Add Reference" window 中的 COM 选项卡,然后向下滚动到您的 Excel 对象库版本(我选择了 15,但您可以选择其他版本版本)。然后单击“确定”。
现在,您的 using 语句看起来应该执行如下操作:
using Excel = Microsoft.Office.Interop.Excel;
此外,请注意您的 oXL 构造函数现在可以是
oXL = new Excel.Application();
我在 SSIS 脚本任务中缺少对 "Microsoft.CSharp.dll" 的引用。要在 Visual Studio 2012 中添加引用,请单击“项目”、“添加引用”,然后在“框架”选项卡中滚动找到 Miscrosoft.CSharp,选中相应的框,然后单击“确定”。
我 运行 一些 C# 代码作为脚本组件的一部分 运行 在我的 SSIS 包中。在我的 SSIS 包的下一步中导入文件之前,我试图打开一个 Excel 文件并更改 sheet 的名称。我在尝试初始化 "oSheet" 的行中遇到错误。
错误说明:“错误 1 找不到编译动态表达式所需的一种或多种类型。是否缺少引用?C:\Temp\Vsta\SSIS_ST110\VstaTP9LtckEMUWOXYp4Zy3YpQ\Vstau3xOw__Ey1kaOxXFoq0ff8g\ScriptMain.cs 107 26 ST_005c649f34584ed6873a7fde862ab2c9 “
我有一段时间没有使用 C#,希望有人能给我指出正确的方向。提前致谢!
代码:
public void Main()
{
String s = (String)Dts.Variables["FilePath"].Value;
String FileName = s.Substring(45,s.Length - 45); //45 = hardcoded value for known index of the start of the file name
MessageBox.Show(FileName);
Excel.Application oXL;
Excel._Workbook oWB;
Excel._Worksheet oSheet;
Excel.Range oRng;
try
{
oXL = new Microsoft.Office.Interop.Excel.Application();
oXL.Visible = false;
oWB = (Excel.Workbook)oXL.Workbooks.Open(s);
oSheet = (Excel._Worksheet)oWB.ActiveSheet;
//oSheet = (Excel._Worksheet)oXL.ActiveSheet;
//oSheet = (Excel._Worksheet)oWB.Worksheets.Item(0);
//oSheet = (Excel._Worksheet)oXL.Worksheets[FileName];
oSheet.Name = "NLTWNH";
oWB.Close(s);
}
catch (Exception ex)
{
//do nothing
}
Dts.TaskResult = (int)ScriptResults.Success;
}
首先,添加对 Microsoft Excel Interop DLL 的引用。您可以通过右键单击解决方案资源管理器中的引用文件夹来执行此操作。然后点击添加引用。
单击 "Add Reference" window 中的 COM 选项卡,然后向下滚动到您的 Excel 对象库版本(我选择了 15,但您可以选择其他版本版本)。然后单击“确定”。
现在,您的 using 语句看起来应该执行如下操作:
using Excel = Microsoft.Office.Interop.Excel;
此外,请注意您的 oXL 构造函数现在可以是
oXL = new Excel.Application();
我在 SSIS 脚本任务中缺少对 "Microsoft.CSharp.dll" 的引用。要在 Visual Studio 2012 中添加引用,请单击“项目”、“添加引用”,然后在“框架”选项卡中滚动找到 Miscrosoft.CSharp,选中相应的框,然后单击“确定”。