
本文档旨在解决在使用 Anvil.Works 服务器部署 spaCy displaCy 可视化时,输出结果出现在 Jupyter Notebook 代码单元格而非期望位置的问题。通过在 displaCy.render 中添加 jupyter=False 参数,可以避免 Jupyter 自动检测,从而将可视化结果正确地呈现在 Anvil 应用中。
在使用 spaCy 的 displaCy 模块进行实体可视化时,如果你的应用部署在 Anvil.Works 服务器上,你可能会遇到一个问题:可视化结果并没有出现在 Anvil 应用的前端,而是意外地显示在你的 Jupyter Notebook 代码单元格中。 这通常是因为 displaCy 默认会尝试检测是否在 Jupyter 环境中运行,并自动将输出渲染到 Notebook 中。
要解决这个问题,你需要在调用 displaCy.render 函数时,显式地禁用 Jupyter 环境的自动检测。 这可以通过添加 jupyter=False 参数来实现。
以下是修改后的代码示例:
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)
return labels在这个修改后的版本中,我们在 displaCy.render 函数中添加了 jupyter=False 参数。 这将告诉 displaCy 不要尝试将输出渲染到 Jupyter Notebook 中,而是将其作为普通的 HTML 字符串返回,从而可以正确地显示在你的 Anvil 应用中。
在原版的基础上做了一下修正评论没有提交正文的问题特价商品的调用连接问题去掉了一个后门补了SQL注入补了一个过滤漏洞浮动价不能删除的问题不能够搜索问题收藏时放入购物车时出错点放入购物车弹出2个窗口修正主题添加问题商家注册页导航连接问题销售排行不能显示更多问题热点商品不能显示更多问题增加了服务器探测 增加了空间使用查看 增加了在线文件编辑增加了后台管理里两处全选功能更新说明:后台的部分功能已经改过前台
注意事项:
- 确保你已经正确安装了 spaCy 和 displaCy 模块。 你可以使用 pip install spacy 和 pip install spacy[displacy] 命令来安装它们。
- 你可能需要安装一个 spaCy 的语言模型。 例如,你可以使用 python -m spacy download en_core_web_sm 命令来安装小型英文模型。
- 确保你的 Anvil 应用能够正确地处理 HTML 字符串,并将其渲染到前端。 这通常可以通过使用 Anvil 的 HTML 组件来实现。
总结:
通过在 displaCy.render 函数中添加 jupyter=False 参数,你可以轻松地解决在使用 Anvil.Works 服务器部署 spaCy displaCy 可视化时,输出结果出现在 Jupyter Notebook 代码单元格的问题。 这将确保你的可视化结果能够正确地显示在你的 Anvil 应用中,从而提高用户体验。









