- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
大家好,
我目前正在开发一个 python 模块,为同事提供使用工具,我试图提供的一些功能可以返回相当多的有用信息(比如 5 个返回值),但在大多数用例中,只需要前两个。
我知道 python 非常适合编写高度动态的程序,尤其是因为我们可以询问有关当前正在运行的系统的信息,所以我想搜索一下,但我似乎找不到。 (我发现了很多有趣的讨论,但没有真正讨论我的问题。)
有没有办法从函数内部知道预期返回值的数量?
例如,可能有函数:
def lazyOdd():
return 1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21
将使用 one, three, five = lazyOdd()
调用。
编辑:显然一点都不清楚,我寻找的看起来像:
def lazyReturn():
return (val1, val2) if expectedReturns == 2 else (val1, val2, val3, val4)
我知道在这种情况下,这绝对不是继续进行的最佳方式,几乎任何一种可迭代对象都可以,但是对于根本没有链接的值,它不会那么简单。如果可能的话,因为大多数用例将只使用两个结果,我想避免返回一个大元组,因为许多同事甚至不知道该函数返回其他值,这将是非常错误的 -俯卧。
我可以这样做吗?
编辑:此外,我不介意解决方案是否包含一些开销,因为我很可能会通过不处理最后三个值来赢得很多时间。
Edit²:也许最好的方法真的是传递另一个指定预期值数量的参数?
最佳答案
从你的描述中很难判断,但你似乎需要caching .
这样,您就可以编写多个函数。一个用于繁重的计算,其他的输出正确的格式和值的数量。如果使用相同的输入值第二次调用繁重的计算,则返回之前的结果。
from functools import lru_cache
@lru_cache(maxsize=32)
def heavy_common_calculation(x):
print("HEAVY CALCULATION FOR %d. Should only be done once!" % x)
result = x**2
return result
def get_two_values(x):
return x, heavy_common_calculation(x)
def get_four_values(x):
y = heavy_common_calculation(x)
return x, y, y**2, y**3
print(get_two_values(3))
# HEAVY CALCULATION FOR 3. Should only be done once!
# (3, 9)
print(get_four_values(3))
# (3, 9, 81, 729)
你想实现一个generator吗? ?
def lazyOdd():
x = 1
while True:
yield x
x = x + 2
odd_gen = lazyOdd()
print(next(odd_gen))
# 1
print(next(odd_gen))
# 3
print(next(odd_gen))
# 5
print(next(odd_gen))
# 7
如果你想要一个值,它会被计算出来。如果您不需要它,则不会发生任何事情,也不会白白计算任何事情。
len(odd_gen)
未定义,因为它会启动无限循环。
您可以使用一个参数来告诉函数您需要多少个结果:
def f(x, detail='low'):
a, b = x, x**2
if detail == 'high':
return a, b, 'something', 'else'
else:
return a, b
print(f(3))
# (3, 9)
print(f(3, detail='high'))
# (3, 9, 'something', 'else')
关于python - "introspect"函数内预期返回量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45351510/
有没有办法自省(introspection)变量以直接找出它声明的子集?在这里,我创建了一个子集,但自省(introspection)将我指向它的基本类型: > subset Prime of Int
我正在尝试使用泛型动态创建一个基于 class 实例的类型,但是我在类自省(introspection)方面遇到了困难。 问题如下: 是否有与 Obj-C 的 self.class 等效的 Swift
首先,一些上下文:我是一名 Python 开发人员,他使用 PyGObject 编写了一个中型应用程序,利用 GObject Introspection 来访问 GSettings 等内容。我的一些
当 API 使用 Introspection 进行 HTTP token 身份验证时,如果 Introspection 服务器关闭或返回 500,它应该返回什么? 我正在编写 API 并希望遵守 Ht
调用子例程 Capture 后访问它的语法是什么? self仅适用于对象和 &?ROUTINE 指的是静态例程,而不是其一旦被调用的状态。那么首先,是否可以访问例程的 Capture从内部?如果是这样
我有一个关于 Java 方法内省(introspection)的问题,特别是关于异常的问题。假设我有以下代码: private String getCustomReportResponse(Https
给定 D 中的函数声明,是否可以在编译时内省(introspection)任何函数参数名称的字符串表示形式,以用于自动函数反射。 例如。 void foo(int a, double b, strin
在 Julia 中,有没有办法获取传递给函数的名称? x = 10 function myfunc(a) # do something here end assert(myfunc(x) == "x"
D语言有没有类似lint之类的东西,或者有没有什么框架可以快速搭建检查器? 编辑 1 回想起来,我记得一周前我看过工具 DScanner。该工具只能返回类名和一些其他内容,但它包含完整的 Lexer
是否有一些自省(introspection)方法允许可靠地获取对象实例的底层数据结构,不受任何自定义的影响? 在 Python 3 中,对象的低级实现可能会被深深地掩盖:可以自定义属性查找,甚至可以自
我正在草拟一些东西的设计(函数的机器学习),它最好需要一种函数式编程语言,还有内省(introspection),特别是能够以某种易于处理的格式检查程序自己的代码的能力,最好还有获得机器的能力生成在运
我有一个由 apollo-server 提供支持的 node.js 项目。我使用自定义@admin对查询、突变和对象字段进行权限检查的指令。对于查询和突变,该指令会引发错误,对于字段,它返回 null
我正在尝试通过 Object 对象的名称 memberName 访问其属性。 我尝试过: new PropertyDescriptor(memberName,object.getClass()).ge
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在为以下相当微不足道的问题寻找 OOP 设计建议。我想避免在不采用访问者模式的情况下使用类型自省(introspection)(例如 Java instanceof 运算符),这是典型的建议。我目
一段时间以来,我一直在尝试解决这个问题,到目前为止,每个人都告诉我这在我身边是不可能的,所以我想尝试一下。 这就是问题所在:人们使用环境变量,但没有正确地测试结果或默默地使用硬编码替代方案。 我想做的
大家好, 我目前正在开发一个 python 模块,为同事提供使用工具,我试图提供的一些功能可以返回相当多的有用信息(比如 5 个返回值),但在大多数用例中,只需要前两个。 我知道 python 非常适
我正在玩自省(introspection),想在运行时提取参数计数和参数名称。是否有可能实现这样的东西? class Greeter def self.greet(name, weekday =
假设我有一个从类方法中调用的自由函数。有没有办法让我在自由函数中反省调用堆栈并确定调用我的对象? def foo(arg1) : s = ? #Introspect call stack and
我希望有人可以帮助我解决以下问题: 我对 java 堆栈自省(introspection)的理解(这里可能有点过于简单化)是一个进程生成一个堆栈帧,然后将其添加到堆栈中。现在,当进程需要进行系统调用时
我是一名优秀的程序员,十分优秀!