在函数中使用 nltk.book 导入

问题描述

我正在尝试编写一个简单的函数,如下所示:

def lexical_diversity(text,word):
    from nltk.book import text
    return 100*text.count(word)/len(set(text))

我知道我可以在函数之前导入文本。但是,我想知道为什么会出现以下错误

导入错误:无法从“nltk.book”导入名称“文本”

它告诉我 nltk 中不存在作为语料库的“文本”——这是真的。但是,我希望用户将文本标识为 text1、text2 或 text3。

解决方法

为了在python中导入库的子模块,您可以使用importlib模块。

import importlib

def lexical_diversity(nltk_sub_module,word):
    
    imported_model_module = importlib.import_module( "nltk.book")
    text = getattr(imported_model_module,nltk_sub_module)

    return 100*text.count(word)/len(set(text))

lexical_diversity("text3","book")

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...