2016-06-11 8 views
0

私はPythonで新しくなっていますので、私と一緒にご負担ください。基本的にはソケットネットワークに関するスクリプトがあります。スクリプト:Pythonソケットネットワーキング - ValueError:list.remove(x):xがリストにありません

class TheServer: 
    input_list = [] 
    channel = {} 
    channel_ = {} 
    request = {} 

    def __init__(self, host, port): 
     self.server = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 
     self.server.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) 
     self.server.bind((host, port)) 
     self.server.listen(200) 

    def main_loop(self): 
     self.input_list.append(self.server) 
     while 1: 
      ss = select.select 
      inputready, outputready, exceptready = ss(self.input_list, [], []) 
      for self.s in inputready: 
       if self.s == self.server: 
        self.on_accept() 
        break 
       try: 
        self.netdata = self.s.recv(buffer_size) 
       except Exception, e: 
        self.netdata ='' 
       if len(self.netdata) == 0: 
        self.on_close() 
       else: 
        if cmp(self.channel[self.s],self.channel_[self.s]): 
         self.on_outbounddata() 
        else: 
         self.on_execute() 

    def on_accept(self): 
     forward = Forward().start(forward_to[0], forward_to[1]) 
     clientsock, clientaddr = self.server.accept() 
     if forward: 
      self.input_list.append(clientsock) 
      self.input_list.append(forward) 
      self.channel[clientsock] = forward 
      self.channel[forward] = clientsock 
      self.channel_[clientsock] = forward 
      self.channel_[forward] = forward 
     else: 
      waktu = datetime.datetime.strftime(datetime.datetime.now(), '%H:%M:%S') 
      with open('/www/dial.log', 'a') as file: 
       file.write(str(waktu) + " Proxy " + str(forward_to[0]) + ":" + str(forward_to[1]) + " isn't responding\n") 
       file.close() 
      print "Proxy " + str(forward_to[0]) + ":" + str(forward_to[1]) + " isn't responding" 
      print "Closing connection with client side", clientaddr 
      clientsock.close() 

    def on_close(self): 
     self.input_list.remove(self.s) 
     self.input_list.remove(self.channel[self.s]) 
     out = self.channel[self.s] 
     self.channel[out].close() 
     self.channel_[out].close() 
     self.channel[self.s].close() 
     self.channel_[self.s].close() 
     del self.channel[out] 
     del self.channel_[out] 
     del self.channel[self.s] 
     del self.channel_[self.s] 



    def on_execute(self): 
     netdata = self.netdata 

あなたはどう思いますかは、上記のスクリプトが間違っている:

Traceback (most recent call last): 
    File "socks", line 293, in <module> 
    server.main_loop() 
    File "socks", line 210, in main_loop 
    self.on_close() 
    File "socks", line 237, in on_close 
    self.input_list.remove(self.s) 
ValueError: list.remove(x): x not in list 

ここで私が持っているスクリプトがですか?そのエラーが発生するたびにスクリプトを手動で再起動する必要があります。

アップデート:アップデート2

Traceback (most recent call last): 
    File "socks", line 296, in <module> 
    server.main_loop() 
    File "socks", line 210, in main_loop 
    self.on_close() 
    File "socks", line 241, in on_close 
    self.input_list.remove(self.channel[self.s]) 
KeyError: <socket._socketobject object at 0x7f0669e93a60> 

私はそれがエラーを解決したが、その後、私はこれを得たと思った、

def on_close(self): 
    try: 
     self.input_list.remove(self.s) 
    except ValueError: 
     print "self.s is not in the list" 
    self.input_list.remove(self.channel[self.s]) 
    out = self.channel[self.s] 
    self.channel[out].close() 
    self.channel_[out].close() 
    self.channel[self.s].close() 
    self.channel_[self.s].close() 

を@Mosesからの提案を試してみました 私のスクリプトをこのように変更しました

def on_close(self): 
    try: 
     self.input_list.remove(self.s) 
    except ValueError: 
     print "self.s is not in the list" 
     pass 
    self.input_list.remove(self.channel.get(self.s, None)) 
    out = self.channel[self.s] 
    self.channel[out].close() 
    self.channel_[out].close() 
    self.channel[self.s].close() 
    self.channel_[self.s].close() 
    del self.channel[out] 
    del self.channel_[out] 
    del self.channel[self.s] 
    del self.channel_[self.s] 

そして、私はまだ、このエラーが出る:

self.s is not in the list 
Traceback (most recent call last): 
    File "socks", line 296, in <module> 
    try: 
    File "socks", line 210, in main_loop 
    self.on_close() 
    File "socks", line 241, in on_close 
    pass 
ValueError: list.remove(x): x not in list 

答えて

0

チェックあなたが持っているアイテムを削除するか、または単にtry-except

if item in lst: 
    lst.remove(item) 
else: 
    pass # you may print some message or log something 

# OR 

try: 
    lst.remove(item) 
except ValueError: 
    pass # you may print some message or log something 
+0

別のエラーが現れた使用する前に、リストに存在する場合、 – hillz

+0

'KeyError' on' self.channel [self.s] 'はキー' self.s'が辞書に存在しないことを意味します。 'self.channel.get(self.s、None)'を実行すると、キーが見つからないときに 'None'が返されます。 –

+0

さらに別のエラーがあります。私の投稿の最新の更新をチェックしてください – hillz

関連する問題