-2

我想在一个函数中发送两个参数并接收两个值

我想修改这段代码,以便我的代码能够发送两个参数并接收两个

list_value = [ 1, 2,0,-1,-9,2,3,5,4,6,7,8,9,0,1,50]
hnd = map(lambda (valua): function_f(valua), list_value)

function_f 是一个返回一个数字 1 或 0 的函数。

上面的代码可以在发送一个参数时完成这项工作,但我想发送两个而不是。所需函数的第一个参数是 list_value,第二个参数是模型“net model train it using caffe”

所以我想写一个函数,它可以做与前一个函数相同的工作,但返回两个参数,一个是 [0 或 1],另一个是这个函数已经修改的修改模型。

4

2 回答 2

6

由于您说您只想要一个模型,而不是每个值的新模型,因此这相当简单。改变:

hnd = map(lambda (valua): function_f(valua), list_value)

至:

model = ... initialize a model that will be passed to every call ...
hnd = map(lambda valua: function_f(valua, model), list_value)

只要确保function_f返回新值和模型,例如,如果它以前这样做:

def function_f(val, model):
    ... calculate newval and make newmodel ...
    return newval

只需将其更改为:

def function_f(val, model):
    ... calculate newval and make newmodel ...
    return newval, newmodel

注意:如果需要使用lambdas来使用map,不要使用map; 它不会给你带来任何好处(在映射函数不是 CPython 内置的大多数情况下,生成器表达式或列表推导将以相同的速度运行,甚至更快)。也就是说,在您的特定情况下,您不需要 a lambda,例如,您可以执行以下操作:

from future_builtins import map  # Only on Py2; Py3 map is good

from itertools import repeat

model = ... initialize a model that will be passed to every call ...
hnd = map(function_f, list_value, repeat(model))

或仅使用生成器表达式(除非该函数是用 C 实现的 Python 内置函数,否则map基本上不会获得性能;如果您不想考虑是否map合适,请始终使用列表推导/生成器表达式而不是mapis好主意):

# Change outside parens to brackets, [], for list comp
hnd = (function_f(x, model) for x in list_value)
于 2016-01-28T15:19:00.763 回答
3

通过使用 zip,您可以使用具有此类功能的地图。我提供了您要求演示的示例代码

ls1 = [1,2,3,4,5]
ls2 = [1,2,3,4,5]
>>> def func(x,y):
    return x+1,y+1

>>> map(lambda (v1, v2): func(v1, v2), zip(ls1, ls2))
[(2, 2), (3, 3), (4, 4), (5, 5), (6, 6)]
于 2016-01-28T15:27:41.310 回答