Skip to main content
Open In ColabOpen on GitHub

BSHTMLLoader

本笔记本提供了快速入门BeautifulSoup4 文档加载器的概述。有关所有__ModuleName__Loader功能和配置的详细文档,请前往API参考

概述

集成详情

本地可序列化JS支持
BSHTMLLoaderlangchain_community

加载器特性

来源文档懒加载原生异步支持
BSHTMLLoader

设置

要访问BSHTMLLoader文档加载器,您需要安装langchain-community集成包和bs4 python包。

凭证

使用BSHTMLLoader类不需要任何凭证。

如果你想获得自动化的最佳模型调用跟踪,你也可以通过取消注释以下内容来设置你的LangSmith API密钥:

# os.environ["LANGSMITH_API_KEY"] = getpass.getpass("Enter your LangSmith API key: ")
# os.environ["LANGSMITH_TRACING"] = "true"

安装

安装 langchain_communitybs4

%pip install -qU langchain_community bs4

初始化

现在我们可以实例化我们的模型对象并加载文档:

  • TODO: 使用相关参数更新模型实例化。
from langchain_community.document_loaders import BSHTMLLoader

loader = BSHTMLLoader(
file_path="./example_data/fake-content.html",
)
API Reference:BSHTMLLoader

加载

docs = loader.load()
docs[0]
Document(metadata={'source': './example_data/fake-content.html', 'title': 'Test Title'}, page_content='\nTest Title\n\n\nMy First Heading\nMy first paragraph.\n\n\n')
print(docs[0].metadata)
{'source': './example_data/fake-content.html', 'title': 'Test Title'}

懒加载

page = []
for doc in loader.lazy_load():
page.append(doc)
if len(page) >= 10:
# do some paged operation, e.g.
# index.upsert(page)

page = []
page[0]
Document(metadata={'source': './example_data/fake-content.html', 'title': 'Test Title'}, page_content='\nTest Title\n\n\nMy First Heading\nMy first paragraph.\n\n\n')

向BS4添加分隔符

我们也可以在调用soup上的get_text时传递一个分隔符

loader = BSHTMLLoader(
file_path="./example_data/fake-content.html", get_text_separator=", "
)

docs = loader.load()
print(docs[0])
page_content='
, Test Title,
,
,
, My First Heading,
, My first paragraph.,
,
,
' metadata={'source': './example_data/fake-content.html', 'title': 'Test Title'}

API 参考

有关所有BSHTMLLoader功能和配置的详细文档,请访问API参考:https://python.langchain.com/api_reference/community/document_loaders/langchain_community.document_loaders.html_bs.BSHTMLLoader.html


这个页面有帮助吗?