mirror of
				https://github.com/hwchase17/langchain.git
				synced 2025-10-23 02:15:42 +00:00 
			
		
		
		
	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)
 |