0

我创建了一个从数据库中的信息生成 excel 文件的应用程序。这些文件保存在我的硬盘上的一个文件夹中。

之后,我附上文件并通过邮件发送。当我生成另一批文件时,我删除旧文件,然后创建新文件。

我的问题是当我生成了一批文件然后发送它们,并且我想生成另一批文件时,我无法删除其中一个旧文件,因为邮寄方法仍在保留其中一个 excel 文件。

这是我的代码:

public void SendMailedFilesDKLol() {
    string[] sentFiles=Directory.GetFiles(some_Folder);

    if(sentFiles.Count()>0) {
        System.Net.Mail.SmtpClient client=new System.Net.Mail.SmtpClient("ares");
        System.Net.Mail.MailMessage msg=new System.Net.Mail.MailMessage();

        msg.From=new MailAddress("system@lol.dk");
        msg.To.Add(new MailAddress("lmy@lol.dk"));
        msg.Subject="IBM PUDO";

        msg.Body=
            sentFiles.Count()+" attached file(s) has been sent to the customer(s) in question ";

        msg.IsBodyHtml=true;

        foreach(string file in sentFiles) {
            Attachment attachment=new Attachment(file);
            msg.Attachments.Add(attachment);
        }

        client.Send(msg);
    }
}

我试图处理客户端元素,但这没有帮助。

谁能帮我这个?

4

3 回答 3

3

System.Net.Mail.MailMessage 和 System.Net.Mail.SmtpClient 都是 IDisposable 类。您可以尝试以下方法,

    using (System.Net.Mail.SmtpClient client = new System.Net.Mail.SmtpClient("ares"))
    {
       using (System.Net.Mail.MailMessage msg = new System.Net.Mail.MailMessage())
       {
          msg.From = new MailAddress("system@lol.dk");
          msg.To.Add(new MailAddress("lmy@lol.dk"));
          msg.Subject = "IBM PUDO";
          msg.Body = sentFiles.Count() + " attached file(s) has been sent to the customer(s) in question ";
          msg.IsBodyHtml = true;
          foreach (string file in sentFiles)
          {
              Attachment attachment = new Attachment(file);
              msg.Attachments.Add(attachment);
          }

          client.Send(msg);
        }
     }
于 2013-03-21T08:41:34.790 回答
0

您需要处置附件对象。使用 LINQ 的示例:

public void SendMailedFilesDKLol() {
    string[] sentFiles=Directory.GetFiles(some_Folder);

    if(sentFiles.Count()>0) {
        System.Net.Mail.SmtpClient client=new System.Net.Mail.SmtpClient("ares");
        System.Net.Mail.MailMessage msg=new System.Net.Mail.MailMessage();

        msg.From=new MailAddress("system@lol.dk");
        msg.To.Add(new MailAddress("lmy@lol.dk"));
        msg.Subject="IBM PUDO";

        msg.Body=
            sentFiles.Count()+" attached file(s) has been sent to the customer(s) in question ";

        msg.IsBodyHtml=true;

        var attachments = sentFiles.Select(f => new Attachment(f)).ToList();

        attachments.ForEach(a => msg.Attachments.Add(a));

        client.Send(msg);

        attachments.ForEach(a => a.Dispose());
    }
}
于 2013-03-21T08:39:31.557 回答
0

听起来您在生成 excel 文件时可能没有关闭文件流,或者在尝试通过电子邮件发送它们时在 excel 中打开它们。

请您显示生成excel文件的代码。

于 2013-03-21T08:31:44.460 回答