mirror of
https://github.com/hwchase17/langchain
synced 2024-11-11 19:11:02 +00:00
ed58eeb9c5
Moved the following modules to new package langchain-community in a backwards compatible fashion: ``` mv langchain/langchain/adapters community/langchain_community mv langchain/langchain/callbacks community/langchain_community/callbacks mv langchain/langchain/chat_loaders community/langchain_community mv langchain/langchain/chat_models community/langchain_community mv langchain/langchain/document_loaders community/langchain_community mv langchain/langchain/docstore community/langchain_community mv langchain/langchain/document_transformers community/langchain_community mv langchain/langchain/embeddings community/langchain_community mv langchain/langchain/graphs community/langchain_community mv langchain/langchain/llms community/langchain_community mv langchain/langchain/memory/chat_message_histories community/langchain_community mv langchain/langchain/retrievers community/langchain_community mv langchain/langchain/storage community/langchain_community mv langchain/langchain/tools community/langchain_community mv langchain/langchain/utilities community/langchain_community mv langchain/langchain/vectorstores community/langchain_community mv langchain/langchain/agents/agent_toolkits community/langchain_community mv langchain/langchain/cache.py community/langchain_community mv langchain/langchain/adapters community/langchain_community mv langchain/langchain/callbacks community/langchain_community/callbacks mv langchain/langchain/chat_loaders community/langchain_community mv langchain/langchain/chat_models community/langchain_community mv langchain/langchain/document_loaders community/langchain_community mv langchain/langchain/docstore community/langchain_community mv langchain/langchain/document_transformers community/langchain_community mv langchain/langchain/embeddings community/langchain_community mv langchain/langchain/graphs community/langchain_community mv langchain/langchain/llms community/langchain_community mv langchain/langchain/memory/chat_message_histories community/langchain_community mv langchain/langchain/retrievers community/langchain_community mv langchain/langchain/storage community/langchain_community mv langchain/langchain/tools community/langchain_community mv langchain/langchain/utilities community/langchain_community mv langchain/langchain/vectorstores community/langchain_community mv langchain/langchain/agents/agent_toolkits community/langchain_community mv langchain/langchain/cache.py community/langchain_community ``` Moved the following to core ``` mv langchain/langchain/utils/json_schema.py core/langchain_core/utils mv langchain/langchain/utils/html.py core/langchain_core/utils mv langchain/langchain/utils/strings.py core/langchain_core/utils cat langchain/langchain/utils/env.py >> core/langchain_core/utils/env.py rm langchain/langchain/utils/env.py ``` See .scripts/community_split/script_integrations.sh for all changes
69 lines
2.6 KiB
Python
69 lines
2.6 KiB
Python
import html
|
|
from typing import Any, Dict, Literal
|
|
|
|
from langchain_core.pydantic_v1 import BaseModel, Field, root_validator
|
|
|
|
|
|
class StackExchangeAPIWrapper(BaseModel):
|
|
"""Wrapper for Stack Exchange API."""
|
|
|
|
client: Any #: :meta private:
|
|
max_results: int = 3
|
|
"""Max number of results to include in output."""
|
|
query_type: Literal["all", "title", "body"] = "all"
|
|
"""Which part of StackOverflows items to match against. One of 'all', 'title',
|
|
'body'. Defaults to 'all'.
|
|
"""
|
|
fetch_params: Dict[str, Any] = Field(default_factory=dict)
|
|
"""Additional params to pass to StackApi.fetch."""
|
|
result_separator: str = "\n\n"
|
|
"""Separator between question,answer pairs."""
|
|
|
|
@root_validator()
|
|
def validate_environment(cls, values: Dict) -> Dict:
|
|
"""Validate that the required Python package exists."""
|
|
try:
|
|
from stackapi import StackAPI
|
|
|
|
values["client"] = StackAPI("stackoverflow")
|
|
except ImportError:
|
|
raise ImportError(
|
|
"The 'stackapi' Python package is not installed. "
|
|
"Please install it with `pip install stackapi`."
|
|
)
|
|
return values
|
|
|
|
def run(self, query: str) -> str:
|
|
"""Run query through StackExchange API and parse results."""
|
|
|
|
query_key = "q" if self.query_type == "all" else self.query_type
|
|
output = self.client.fetch(
|
|
"search/excerpts", **{query_key: query}, **self.fetch_params
|
|
)
|
|
if len(output["items"]) < 1:
|
|
return f"No relevant results found for '{query}' on Stack Overflow."
|
|
questions = [
|
|
item for item in output["items"] if item["item_type"] == "question"
|
|
][: self.max_results]
|
|
answers = [item for item in output["items"] if item["item_type"] == "answer"]
|
|
results = []
|
|
for question in questions:
|
|
res_text = f"Question: {question['title']}\n{question['excerpt']}"
|
|
relevant_answers = [
|
|
answer
|
|
for answer in answers
|
|
if answer["question_id"] == question["question_id"]
|
|
]
|
|
accepted_answers = [
|
|
answer for answer in relevant_answers if answer["is_accepted"]
|
|
]
|
|
if relevant_answers:
|
|
top_answer = (
|
|
accepted_answers[0] if accepted_answers else relevant_answers[0]
|
|
)
|
|
excerpt = html.unescape(top_answer["excerpt"])
|
|
res_text += f"\nAnswer: {excerpt}"
|
|
results.append(res_text)
|
|
|
|
return self.result_separator.join(results)
|