如何向apply函数传递多个参数

2024-05-15 04:39:48 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个叫做counting的方法,它有两个参数。我需要使用apply()方法调用这个方法。但是,当我将这两个参数传递给apply方法时,它会给出以下错误:

TypeError: counting() takes exactly 2 arguments (1 given)

我已经看到下面的线程python pandas: apply a function with arguments to a series. Update,我不想使用functool.partial,因为我不想导入其他类来传递参数。

def counting(dic, strWord):
    if strWord in dic:
        return dic[strWord]
    else:
        return 0

DF['new_column'] = DF['dic_column'].apply(counting, 'word')

如果我只给出一个参数,它就会工作:

def awesome_count(dic):
    if strWord in dic:
       return dic[strWord]
    else:
       return 0

DF['new_column'] = DF['dic_column'].apply(counting)

Tags: 方法indfnew参数returnifdef
2条回答

公认的答案是完全完美的。教了我一些关于Python的有趣的东西。但只是为了好玩,我们要找的更准确:

selected_words =  ['awesome', 'great', 'fantastic', 'amazing', 'love', 'horrible', 'bad', 'terrible', 'awful', 'wow', 'hate']
for this_word in selected_words:
    products[this_word] = products['word_count'].apply(lambda dic: dic.get(this_word, 0))

谢谢你把问题贴出来!

您可以使用lambda

DF['new_column'] = DF['dic_column'].apply(lambda dic: counting(dic, 'word'))

另一方面,在这里使用partial绝对没有问题:

from functools import partial
count_word = partial(counting, strWord='word')
DF['new_column'] = DF['dic_column'].apply(count_word)

正如@EdChum提到的,如果您的counting方法实际上只是查找一个单词或将其默认为零,那么您可以使用方便的dict.get方法而不是自己编写一个:

DF['new_column'] = DF['dic_column'].apply(lambda dic: dic.get('word', 0))

以及通过operator模块执行上述操作的非lambda方法:

from operator import methodcaller
count_word = methodcaller(get, 'word', 0)
DF['new_column'] = DF['dic_column'].apply(count_word)

相关问题 更多 >

    热门问题