Et j'aimerais y parvenir avec la construction try catch.
Cette question liée suggère que je puisse faire:
try:
open(fileName, 'wb+')
except:
print("File already opened!")
raise
Cependant, cela ne me fonctionne pas. Je peux ouvrir le même fichier plusieurs fois sans problème:
fileObj1 = open(fileName, 'wb+')
fileObj2 = open(fileName, 'wb+')
Est-ce parce que j'ai Python 3.5? Ou parce que j'utilise Raspbian ?
Merci pour l'aide!
Vous ouvrez le même fichier mais vous les affectez à différentes variables. Ce que vous devriez faire est:
fileobj=open(filename,"wb+")
if not fileobj.closed:
print("file is already opened")`
J'écris avec mon téléphone, le style n'est peut-être pas très bon mais vous comprendrez. En passant, le .closed
ne vérifie que si le fichier a été ouvert par le même processus python.
Je suggère d'utiliser quelque chose comme ça.
def is_open(file_name):
if os.path.exists(file_name):
try:
os.rename(file_name, file_name) #can't rename an open file so an error will be thrown
return False
except:
return True
raise NameError
Édité pour répondre aux problèmes spécifiques du PO
class FileObject(object):
def __init__(self, file_name):
self.file_name = file_name
self.__file = None
self.__locked = False
@property
def file(self):
return self.__file
@property
def locked(self):
return self.__locked
def open(self, mode, lock=True):#any testing on file should go before the if statement such as os.path.exists()
#replace mode with *args if you want to pass multiple modes
if not self.locked:
self.__locked = lock
self.__file = open(self.file_name, mode)
return self.file
else:
print 'Cannot open file because it has an exclusive lock placed on it'
return None #do whatever you want to do if the file is already open here
def close(self):
if self.file != None:
self.__file.close()
self.__file = None
self.__locked = False
def unlock(self):
if self.file != None:
self.__locked = False