gpt4 book ai didi

python - 属性错误 : 'str' object has no attribute '__module__'

转载 作者:太空狗 更新时间:2023-10-30 02:32:23 24 4
gpt4 key购买 nike

我一直在测试这个缓存方法/代码: http://code.activestate.com/recipes/498245-lru-and-lfu-cache-decorators/?c=15348

在某些情况下,我会收到此(或类似)错误:“AttributeError:‘str’对象没有属性‘模块’”

这里是代码示例,它们工作正常:

if __name__ == '__main__':
@lru_cacheItem(maxsize=20)
def f(x, y):
return 3*x+y

domain = range(5)
from random import choice
for i in range(1000):
r = f(choice(domain), choice(domain))

print('Hits:{0}'.format(f.hits), 'Misses:{0}'.format(f.misses))

@lfu_cacheItem(maxsize=20)
def f(x, y):
return 3*x+y

domain = range(5)
from random import choice
for i in range(1000):
r = f(choice(domain), choice(domain))

print('Hits:{0}'.format(f.hits), 'Misses:{0}'.format(f.misses))


@lru_cacheItem(maxsize=20)
def myString(a, b):
return '{0} and {1}'.format(a, b)

a = 'crap'
b = 'shit'
for i in range(1000):
r = myString(a, b)

print('Hits:{0}'.format(myString.hits), 'Misses:{0}'.format(myString.misses))

这不是:

if __name__ == '__main__':    
class P4client(object):
def __init__(self):
pass

def checkFileStats(self, filePath):
results = 'The filepath: {0}'.format(filePath)
print results
return results

p4client = P4client()

filePath = (r"C:\depot\tester.tga")

@lfu_cacheItem
def p4checkFileStats(filePath):
'''Will cache the fstats return'''
p4checkResults = p4client.checkFileStats(filePath)
return p4checkResults

p4checkFileStats(filePath)

我不确定如何解决这个问题......这似乎是 functools 中的一个问题,我假设我正在调用我正在包装的函数中的类/方法这一事实以某种方式解决了这个问题?

最佳答案

@lfu_cacheItem            
def p4checkFileStats(filePath):

此处缺少括号:

@lfu_cacheItem()            
def p4checkFileStats(filePath):

所有期望“选项”的装饰器,即您可以用作:

@decorator(a=Something, b=Other, ...)
def the_function(...):

必须在装饰时始终被调用,即使您没有提供参数:

@decorator()
def the_function(...):

你为什么想知道?好吧,首先要记住装饰器是接受函数作为参数的普通函数:

In [1]: def hooray(func):
...: print("I'm decorating function: {.__name__}".format(func))
...: return func

In [2]: @hooray
...: def my_function(): pass
I'm decorating function: my_function

如您所见,万岁调用。事实上,这就是使用装饰器时真正发生的事情:

In [3]: def my_function(): pass
...: my_function = hooray(my_function)
...:
I'm decorating function: my_function

现在,如果您想将选项传递给装饰器,您可以创建一个返回装饰器 的函数。这正是您链接的食谱中的 lfu_cache 发生的情况:

def lfu_cache(maxsize=100):
# ...
def decorating_function(user_function):
# ...
return decorating_function

现在在这里你可以看到 lfu_cache 确实是一个函数。此函数创建 一个装饰器,称为decorating_function 并返回它。这意味着调用时:

@lfu_cache(maxsize=20)
def my_function(): pass

是这样的:

def my_function(): pass
decorator = lfu_cache(maxsize=20)
my_function = decorator(my_function)

正如您首先看到的,lfu_cache 被调用,并返回一个装饰器。然后调用装饰器来装饰函数。如果忘记括号会怎样?这是做什么的:

@lfu_cache
def my_function(): pass

做吗?

非常简单,它使用 lfu_cache 作为一个简单的装饰器:

def my_function(): pass
my_function = lfu_cache(my_function)

但这很糟糕!您将函数作为 maxsize 参数传递,而 lfu_cache 返回的值是之前的 decorating_function!

要了解有关装饰器的更多信息,请阅读 this所以回答。

关于python - 属性错误 : 'str' object has no attribute '__module__' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18493879/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com