无法关闭csv以将其删除

问题描述

我的日常任务非常适合自动化,因此我决定将其用作学习Python的项目。我需要做的是将几个.xlsx文件转换为.csv,然后通过电子邮件将其分别发送到特定的电子邮件地址。

下面是我所拥有的,它可以正常工作直到快要结束。我希望它删除已发送的csv副本。 File1.csv被删除,但file2.csv未被删除,因为它仍在另一个进程中打开。

PermissionError:[WinError 32]该进程无法访问文件,因为该文件正在被另一个进程使用:'C:\ Drop \ file2.csv'

因此很显然,需要关闭csv,但我只是无法弄清楚哪个进程已打开以及如何关闭它。

set.seed(42)
DT <- data.table(MEAN = c(0.5,0.7,0.9),MIN = c(0.4,0.6,0.8),MAX = c(0.6,0.8,1),REF = rnorm(3,1000,200))
DT[,Sim_rtri := Map(function(w,x,y,z) w*(1+rtri(n = 1000,min = x,max = y,mode = z)),REF,MIN,MAX,MEAN)]
DT[,Mean_Sim_rtri := sapply(Sim_rtri,mean)]
DT[,Int_Sim_rtri := lapply(Sim_rtri,ci,method = "ETI",ci = .95)]

DT
   MEAN MIN MAX       REF                                                  Sim_rtri Mean_Sim_rtri     Int_Sim_rtri
1:  0.5 0.4 0.6 1274.1917 1946.223,1849.996,1933.170,1940.845,1905.784,1943.204,...      1908.901 <bayestestR_eti>
2:  0.7 0.6 0.8  887.0604 1512.938,1530.315,1480.203,1542.298,1500.740,1513.961,...      1507.717 <bayestestR_eti>
3:  0.9 0.8 1.0 1072.6257 2055.113,2085.123,1991.335,2022.209,2010.288,1984.313,...      2038.466 <bayestestR_eti>

解决方法

您的错误是打开attachment而从未关闭。

代替:attachment = open(attached_file,'rb')

使用with open()上下文管理器:

with open(attached_file,'rb') as attachment:
    part = MIMEBase('application','octet-stream')
    part.set_payload((attachment).read())
# here attachment is closed automatically
encoders.encode_base64(part)
part.add_header('Content-Disposition',"attachment; filename= "+attached_file)