属性错误:函数对象在python中没有属性

时间:2013-09-12 00:13:18

标签: python multithreading logging attributes

这是我调用函数10次并测量时间的代码

    import threading
    import logging, logging.handlers
    import hpclib
    import json
    import time
    from datetime import datetime
    from features import *


    class FuncThread(threading.Thread):
        def __init__(self, target, *args):
            self._target = target
            self._args = args
            threading.Thread.__init__(self)

        def run(self):
            self._target(*self._args)

    def datapaths(ipaddress, testlogfile):
        #initialize logging system
        testlogger = logging.getLogger("testlogger")
        testlogger.setLevel(logging.DEBUG)
        file = open(testlogfile,'w')
        file.close()
        # This handler writes everything to a file.
        h1 = logging.FileHandler(testlogfile)
        f = logging.Formatter("%(levelname)s %(asctime)s %(funcName)s %(lineno)d %(message)s")
        h1.setFormatter(f)
        h1.setLevel(logging.DEBUG)
        testlogger.addHandler(h1)
        mylib = hpclib.hpclib(ipaddress)
        for i in range(10):
            t1=datetime.now().time()
            (code, val) = datapaths.listDatapaths(mylib)
            t2=datetime.now().time()
            diff=t2-t1
            logger.debug('RETURN code: ', code)
            logger.debug('Time taken in seconds: ',diff.seconds)

        testlogger.removeHandler(h1)

    # Passing ipaddress of controller and log file name
    t1 = FuncThread(datapaths, "103.0.1.40", "datapaths.log")
    t1.start()
    t1.join()

当我尝试在线程中调用函数时运行此代码时出现属性错误。 这是我得到的错误。 请帮我解决这个问题。

Traceback (most recent call last):
  File "/usr/lib/python2.7/threading.py", line 551, in __bootstrap_inner
    self.run()
  File "code.py", line 17, in run
    self._target(*self._args)
  File "code.py", line 34, in datapaths
    (code, val) = datapaths.listDatapaths(mylib)
AttributeError: 'function' object has no attribute 'listDatapaths'

1 个答案:

答案 0 :(得分:0)

只是为了得到答案:

def datapaths(ipaddress, testlogfile):
        # Unecessary code reomved
        (code, val) = datapaths.listDatapaths(mylib)
        # Unecessary code reomved

您正在尝试访问您已定义的功能的属性,但很可能未设置。我认为你需要重新审视你的代码。