0

シンプルなチャット サーバーがあり、新しいクライアントが接続するたびにデータベースにクエリを実行したいと考えています。twistar CRUD インターフェイスで試してみましたが、奇妙なエラーが発生しました:

exceptions.NameError: グローバル名 'result' が定義されていません

from twisted.internet.protocol import Factory
from twisted.protocols.basic import LineReceiver
from twisted.enterprise import adbapi
from twisted.internet import reactor
from twistar.registry import Registry
from twistar.dbobject import DBObject

Registry.DBPOOL = adbapi.ConnectionPool('MySQLdb', host="localhost", db="testdb", user="test", passwd="test")
dbconfig = Registry.getConfig()

class Chat(LineReceiver):

    # Here is the callback
    def result(values):
        print values

    def __init__(self, users):
        self.users = users
        self.name = None
        self.state = "GETNAME"

    def connectionMade(self):
        self.sendLine("What's your name?")

    def connectionLost(self, reason):
        if self.users.has_key(self.name):
            del self.users[self.name]

    def lineReceived(self, line):
        if self.state == "GETNAME":
            self.handle_GETNAME(line)
        else:

    def handle_GETNAME(self, name):
        if self.users.has_key(name):
            self.sendLine("Name taken, please choose another.")
            return
        self.sendLine("Welcome, %s!" % (name,))
        # Here is the query
        d = dbconfig.select("testtable").addCallback(result)**

        self.name = name
        self.users[name] = self
        self.state = "CHAT"

    def handle_CHAT(self, message):
        message = "<%s> %s" % (self.name, message)
        for name, protocol in self.users.iteritems():
            if protocol != self:
                protocol.sendLine(message)

def result(var):
       print var

class ChatFactory(Factory):

    def __init__(self):
        self.users = {} # maps user names to Chat instances

    def buildProtocol(self, addr):
        return Chat(self.users)

reactor.listenTCP(8000, ChatFactory())
reactor.run()

チャット サーバーの外では、CRUD db クエリは問題なく動作します。

前もって感謝します

4

1 に答える 1

2

result がクラスのメンバーである場合、先頭に self を付ける必要があります。

 d = dbconfig.select("testtable").addCallback(self.result)**
于 2012-09-22T19:13:43.800 に答える