这是我在Stack Overflow上的第一篇文章,肯定不会是最后一篇。我有一个非常艰难的一周试图解决我的SST脚本任务在SSDT for VS2015的问题。
问题如下:
我在控制流程中有一个ForEach循环容器。我映射变量USER::FileName
。这个变量用于处理Script Task
中的excel文件(用点替换逗号),然后保存处理过的文件并将其转换为数据流任务中的平面文件。到现在为止还挺好。但是在ForEach循环容器的第二个循环中,原始的excel文件未正确处理。名称设置正确但不替换逗号。我不知道该怎么办了。也许有人有任何建议?
编辑2:这就是Script Task Code
的样子:
using Excel = Microsoft.Office.Interop.Excel;
[Microsoft.SqlServer.Dts.Tasks.ScriptTask.SSISScriptTaskEntryPointAttribute]
public partial class ScriptMain : Microsoft.SqlServer.Dts.Tasks.ScriptTask.VSTARTScriptObjectModelBase
{
public void Main()
{
Excel._Application oApp = new Excel.Application();
Excel.Workbook oWorkbook = oApp.Workbooks.Open(Dts.Variables["User::SourcePath"].Value.ToString() + "\\" + Dts.Variables["User::FileName"].Value.ToString() + ".xls");
Excel.Worksheet oWorksheet = oWorkbook.Worksheets[1];
try
{
ChangeValues(oWorksheet);
oWorkbook.SaveAs("C:\\TEMP\\" + Dts.Variables["User::FileName"].Value.ToString() + ".xls");
oWorkbook.Close();
oApp.Quit();
oWorksheet = null;
oWorkbook = null;
oApp = null;
GC.Collect();
GC.WaitForPendingFinalizers();
GC.Collect();
GC.WaitForPendingFinalizers();
Dts.TaskResult = (int)ScriptResults.Success;
}
catch (Exception e)
{
Dts.Events.FireError(0, "Script task", e.Message + "\r" + e.StackTrace, String.Empty, 0);
}
}
private static void ChangeValues(Excel.Worksheet oWorksheet)
{
Excel.Range range = oWorksheet.UsedRange;
int colNo = range.Columns.Count;
int rowNo = range.Rows.Count;
// read the values into an array.
object[,] cells = range.Value;
for (int j = 1; j <= colNo; j++)
{
for (int i = 1; i <= rowNo; i++)
{
if (j > 3 && cells[i, j] != null)
{
cells[i, j] = cells[i, j].ToString().Replace(",", ".");
}
}
}
// set the values back into the range.
range.Value = cells;
return;
}
}
答案 0 :(得分:0)
好的,我知道这篇文章有点陈旧但几个星期后我找到了问题的解决方案,并希望与你们快速分享。为了调试代码,我必须在VM上安装Windows 10和VS2017,因为在SSIS中运行脚本任务的Visual Studio Tools for Application(VSTA)调试器在VS2015上不起作用,并且在Windows 7上VS2017不能使用SSDT。所以我能够在VS2017中调试Windows 10上的脚本,发现我的代码没有打开正确的Excel工作表。希望它可以帮助其他任何调试SSIS脚本任务的人。