langchain_community.vectorstores.elasticsearch
.ExactRetrievalStrategy¶
- class langchain_community.vectorstores.elasticsearch.ExactRetrievalStrategy(*args, **kwargs)[source]¶
已弃用版本 0.0.27: 请使用
langchain-elasticsearch 包中的 class
代替。使用 script_score 查询的精确检索策略。
方法
__init__
(*args, **kwargs)before_index_setup
(client, text_field, ...)在索引创建之前执行。
index
(dims_length, vector_query_field, ...)为 Elasticsearch索引创建映射。
query
(query_vector, query, k, fetch_k, ...)在存储上进行搜索时执行。
返回该策略是否需要在将文本添加到索引之前执行推理。
- __init__(*args: Any, **kwargs: Any) Any ¶
- 参数
self (Any) –
args (Any) –
kwargs (Any) –
- 返回类型
Any
- before_index_setup(client: Elasticsearch, text_field: str, vector_query_field: str) None ¶
在索引创建之前执行。用于设置任何必需的 Elasticsearch 资源,如管道。
- 参数
client (Elasticsearch) – Elasticsearch 客户端。
text_field (str) – 索引中包含文本数据的字段。
vector_query_field (str) – 索引中包含向量表示的字段。
- 返回类型
None
- index(dims_length: Optional[int], vector_query_field: str, similarity: Optional[DistanceStrategy]) Dict [source]¶
为 Elasticsearch索引创建映射。
- 参数
dims_length (Optional[int]) –
vector_query_field (str) –
similarity (Optional[DistanceStrategy]) –
- 返回类型
字典
- query(query_vector: Optional[List[float]], query: Optional[str], k: int, fetch_k: int, vector_query_field: str, text_field: str, filter: Optional[List[dict]], similarity: Optional[DistanceStrategy]) Dict [source]¶
在存储上进行搜索时执行。
- 参数
query_vector (Optional[List[float]]) – 查询向量,如果不使用基于向量的查询则为 None。
query (Optional[str]) – 文本查询,如果不使用基于文本的查询则为 None。
k (int) – 要检索的总结果数。
fetch_k (int) – 初次检索的结果数。
vector_query_field (str) – 索引中包含向量表示的字段。
text_field (str) – 索引中包含文本数据的字段。
filter (Optional[List[dict]]) – 应用到查询的过滤器子句列表。
相似度 (可选[DistanceStrategy]) - 要使用的相似度策略,如果不使用则使用 None。
- 返回值
Elasticsearch 查询体。
- 返回类型
字典
- require_inference() bool
返回该策略是否需要在将文本添加到索引之前执行推理。
- 返回值
该策略是否需要在将文本添加到索引之前执行推理。
- 返回类型
bool