Je veux que ce code ne casse jamais. J'ai donc créé une boucle infinie et un "goto" au début en cas de rupture. Cependant, ça ne marche toujours pas.Python: Toujours exécuter le programme
[email protected]:~# cat gmail2.py
import imaplib, re
import os
import time
import socket
socket.setdefaulttimeout(60)
def again():
conn = imaplib.IMAP4_SSL("imap.gmail.com", 993)
conn.login("[email protected]", "xxx")
while(True):
unreadCount = re.search("UNSEEN (\d+)", conn.status("INBOX", "(UNSEEN)")[1][0]).group(1)
print unreadCount
if int(unreadCount) > 20:
os.system('heroku restart --app sss-xxxx-203')
#os.system('ls')
#print "Restarting server...."
time.sleep(60)
again()
1
Traceback (most recent call last):
File "gmail2.py", line 22, in <module>
again()
File "gmail2.py", line 12, in again
unreadCount = re.search("UNSEEN (\d+)", conn.status("INBOX", "(UNSEEN)")[1][0]).group(1)
File "/usr/lib/python2.6/imaplib.py", line 703, in status
typ, dat = self._simple_command(name, mailbox, names)
File "/usr/lib/python2.6/imaplib.py", line 1060, in _simple_command
return self._command_complete(name, self._command(name, *args))
File "/usr/lib/python2.6/imaplib.py", line 890, in _command_complete
raise self.abort('command: %s => %s' % (name, val))
imaplib.abort: command: STATUS => socket error: EOF
Votre connexion, à l'intérieur de votre appel de recherche, ne reçoit aucune donnée ou touche la fin d'un fichier et c'est pourquoi elle renvoie une erreur de socket. Peut-être ajouter une vérification pour EOF avant d'appeler re.search(). En outre, les boucles généralement sans fin sont dangereuses, vous pourriez vouloir ajouter une sorte de condition de rupture. – kand
Ou attraper l'exception. – MRAB