Is there a map without result in python?

前端 未结 15 1026
北恋
北恋 2020-12-03 04:33

Sometimes, I just want to execute a function for a list of entries -- eg.:

for x in wowList:
   installWow(x, \'installed by me\')

Sometime

相关标签:
15条回答
  • 2020-12-03 05:27

    Let me preface this by saying that it seems the original poster was more concerned about namespace clutter than anything else. In that case, you can wrap your working variables in separate function namespace and call it after declaring it, or you can simply remove them from the namespace after you've used them with the "del" builtin command. Or, if you have multiple variables to clean up, def the function with all the temp variables in it, run it, then del it.

    Read on if the main concern is optimization:

    Three more ways, potentially faster than others described here:

    1. For Python >= 2.7, use collections.deque((installWow(x, 'installed by me') for x in wowList),0) # saves 0 entries while iterating the entire generator, but yes, still has a byproduct of a final object along with a per-item length check internally
    2. If worried about this kind of overhead, install cytoolz. You can use count which still has a byproduct of incrementing a counter but it may be a smaller number of cycles than deque's per-item check, not sure. You can use it instead of any() in the next way:
    3. Replace the generator expression with itertools.imap (when installWow never returns True. Otherwise you may consider itertools.ifilter and itertools.ifilterfalse with None for the predicate): any(itertools.imap(installWow,wowList,itertools.repeat('installed by me')))

    But the real problem here is the fact that a function returns something and you do not want it to return anything.. So to resolve this, you have 2 options. One is to refactor your code so installWow takes in the wowList and iterates it internally. Another is rather mindblowing, but you can load the installWow() function into a compiled ast like so:

    lines,lineno=inspect.getsourcelines(func) # func here is installWow without the parens
    return ast.parse(join(l[4:] for l in lines if l)) # assumes the installWow function is part of a class in a module file.. For a module-level function you would not need the l[4:]
    

    You can then do the same for the outer function, and traverse the ast to find the for loop. Then in the body of the for loop, insert the instalWow() function ast's function definition body, matching up the variable names. You can then simply call exec on the ast itself, and provide a namespace dictionary with the right variables filled in. To make sure your tree modifications are correct, you can check what the final source code would look like by running astunparse.

    And if that isn't enough you can go to cython and write a .pyx file which will generate and compile a .c file into a library with python bindings. Then, at least the lost cycles won't be spent converting to and from python objects and type-checking everything repeatedly.

    0 讨论(0)
  • 2020-12-03 05:33

    You might try this:

    filter(lambda x: installWow(x, 'installed by me') and False, wowList)
    

    That way, the return result is an empty list no matter what.

    Or you could just drop the and False if you can force installWow() to always return False (or 0 or None or another expression that evaluates false).

    0 讨论(0)
  • 2020-12-03 05:33

    A simple DIY whose sole purpose is to loop through a generator expression:

    def do(genexpr):
        for _ in genexpr:
            pass
    

    Then use:

    do(installWow(x, 'installed by me') for x in wowList)
    
    0 讨论(0)
提交回复
热议问题