boxmoe_header_banner_img

Hello! 欢迎来到悠悠畅享网!

文章导读

使用 spaCy displacy 在 Anvil 应用中正确显示实体可视化


avatar
站长 2025年8月6日 8

使用 spaCy displacy 在 Anvil 应用中正确显示实体可视化

本文档旨在解决在使用 Anvil.works 服务器部署 spaCy 应用时,displacy.render 的输出无法在 Anvil 应用界面正确显示,而是出现在 Jupyter Notebook 代码单元格中的问题。通过设置 jupyter=False 参数,可以避免 Jupyter 环境的自动检测,确保可视化结果正确返回到 Anvil 应用。

在使用 spaCy 的 displacy 模块进行实体可视化时,如果应用部署在 Anvil.works 服务器上,可能会遇到一个问题:displacy.render 的输出并没有出现在 Anvil 应用的界面上,而是意外地显示在 Jupyter Notebook 的代码单元格中。 这通常是因为 displacy.render 默认会尝试检测是否运行在 Jupyter 环境中,并针对 Jupyter 环境进行优化输出。

要解决这个问题,只需在调用 displacy.render 时,显式地设置 jupyter=False 参数,即可避免 Jupyter 环境的自动检测,确保可视化结果正确返回到 Anvil 应用。

以下是修改后的代码示例:

def visualize_entities_in_sentences(self, doc_id):     """Visualize entities in the sentences of a document.      :param doc_id: the id of the document to visualize     :type doc_id: str     """     doc = self.get_document(doc_id)     sentences = list(doc.sents)     labels = displacy.render(sentences, style="ent", page=False, minify=True, jupyter=False) # 添加 jupyter=False     return labels

解释:

  • jupyter=False: 这个参数告诉 displacy.render 不要尝试以 Jupyter Notebook 友好的方式渲染输出。这确保了输出结果是标准的 HTML,可以被 Anvil 应用正确解析和显示。

注意事项:

  • 确保已经正确安装了 spaCy 和 displacy 模块。
  • 检查 Anvil 应用的代码,确保正确接收并显示 displacy.render 返回的 HTML 内容。通常,你需要将返回的 HTML 字符串插入到 Anvil 应用的 HTML 组件中。

总结:

通过在 displacy.render 函数中添加 jupyter=False 参数,可以有效解决 spaCy 在 Anvil.works 服务器上实体可视化输出显示位置错误的问题。 这种方法简单直接,可以确保可视化结果正确呈现在 Anvil 应用的界面上,提高用户体验。 记住,在将 spaCy 应用部署到非 Jupyter 环境时,显式地设置 jupyter=False 是一个良好的实践。



评论(已关闭)

评论已关闭