0

我正在使用 EPPLUS 从数据库表生成 Excel 文件,但创建的文件保持只读模式,直到整个 SSIS 进程停止。我需要在该过程的后期移动文件,这将始终失败,并在 SSIS 中显示以下消息:

[文件系统任务] 错误:发生错误并显示以下错误消息:“该进程无法访问该文件,因为它正被另一个进程使用。”。

当我尝试在 excel 中打开文件时,我得到了“正在使用的文件”

book1.xlsx 被“另一个用户”锁定以进行编辑。打开“只读”或单击“通知”以只读方式打开并在文档不再使用时收到通知。我希望你能帮助我。

这是我的代码:

   public void Main()
    {
        try
        {
            String FilePath = Dts.Variables["$Package::DestinationFileName"].Value.ToString();
            String TableName = Dts.Variables["$Package::SourceTableName"].Value.ToString();
            String ConnStr = Dts.Variables["$Project::ConnStr_DataWarehouse"].Value.ToString();

            //SqlConnection Conn = (SqlConnection)(Dts.Connections["DW"].AcquireConnection(Dts.Transaction) as SqlConnection);
            using (SqlConnection Conn = new SqlConnection(ConnStr))
            {
                String Sql = "SELECT * FROM " + TableName;
                if (File.Exists(FilePath))
                {
                    try { File.Delete(FilePath); }
                    catch (Exception ex) { MessageBox.Show(ex.Message.ToString()); Dts.TaskResult = (int)ScriptResults.Failure; }
                }
                using (DataTable dt = new DataTable())
                {
                    using (SqlCommand cmd = new SqlCommand(Sql, Conn))
                    {
                        Conn.Open();
                        using (SqlDataAdapter da = new SqlDataAdapter(cmd))
                        {
                            da.Fill(dt);
                            FileInfo newFile = new FileInfo(FilePath);
                            using (ExcelPackage p = new ExcelPackage(newFile))
                            {
                                using (ExcelWorksheet ws = p.Workbook.Worksheets.Add("RejectetionReport"))
                                {
                                    ws.Cells["A1"].LoadFromDataTable(dt, true);
                                    p.Save();
                                }
                            }
                        }
                        Conn.Close();
                    }
                } 
            }

            Dts.TaskResult = (int)ScriptResults.Success;
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message.ToString());
            Dts.TaskResult = (int)ScriptResults.Failure;
        }
    }

我正在使用 EPPLUS 4.0.5,我计划将其更新到 4.1,但发行说明并未涵盖此问题。

编辑: 我已经升级到 4.1,但问题仍然存在。

4

1 回答 1

1

我发现了这个问题。EPPLUS 库中有一个错误,它在处理包之前没有处理流。我已经在 fork DebugPackageDispose下提交了一个修复请求

希望这将很快整合。

于 2016-07-25T11:49:24.033 回答