SSIS脚本任务不适用于ForEach循环容器的第二次迭代

时间:2017-09-07 10:37:46

标签: ssis foreach-loop-container script-task


这是我在Stack Overflow上的第一篇文章,肯定不会是最后一篇。我有一个非常艰难的一周试图解决我的SST脚本任务在SSDT for VS2015的问题。
问题如下:
我在控制流程中有一个ForEach循环容器。我映射变量USER::FileName。这个变量用于处理Script Task中的excel文件(用点替换逗号),然后保存处理过的文件并将其转换为数据流任务中的平面文件。到现在为止还挺好。但是在ForEach循环容器的第二个循环中,原始的excel文件未正确处理。名称设置正确但不替换逗号。我不知道该怎么办了。也许有人有任何建议?

enter image description here

编辑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;
        }
 }

1 个答案:

答案 0 :(得分:0)

好的,我知道这篇文章有点陈旧但几个星期后我找到了问题的解决方案,并希望与你们快速分享。为了调试代码,我必须在VM上安装Windows 10和VS2017,因为在SSIS中运行脚本任务的Visual Studio Tools for Application(VSTA)调试器在VS2015上不起作用,并且在Windows 7上VS2017不能使用SSDT。所以我能够在VS2017中调试Windows 10上的脚本,发现我的代码没有打开正确的Excel工作表。希望它可以帮助其他任何调试SSIS脚本任务的人。