Source code for langchain_community.utilities.scenexplain

"""调用SceneXplain的工具。

为了设置这个工具,您需要SceneXplain API的API密钥。
您可以按照以下步骤获取密钥。
- 在https://scenex.jina.ai/注册一个免费账户。
- 转到API访问页面(https://scenex.jina.ai/api)并创建一个新的API密钥。
"""
from typing import Dict

import requests
from langchain_core.pydantic_v1 import BaseModel, BaseSettings, Field, root_validator
from langchain_core.utils import get_from_dict_or_env


[docs]class SceneXplainAPIWrapper(BaseSettings, BaseModel): """用于SceneXplain API的包装器。 为了设置这个,您需要SceneXplain API的API密钥。 您可以按照以下步骤获取密钥。 - 在https://scenex.jina.ai/注册一个免费账户。 - 转到API访问页面(https://scenex.jina.ai/api) 并创建一个新的API密钥。""" scenex_api_key: str = Field(..., env="SCENEX_API_KEY") scenex_api_url: str = "https://api.scenex.jina.ai/v1/describe" def _describe_image(self, image: str) -> str: headers = { "x-api-key": f"token {self.scenex_api_key}", "content-type": "application/json", } payload = { "data": [ { "image": image, "algorithm": "Ember", "languages": ["en"], } ] } response = requests.post(self.scenex_api_url, headers=headers, json=payload) response.raise_for_status() result = response.json().get("result", []) img = result[0] if result else {} return img.get("text", "") @root_validator(pre=True) def validate_environment(cls, values: Dict) -> Dict: """验证环境中是否存在API密钥。""" scenex_api_key = get_from_dict_or_env( values, "scenex_api_key", "SCENEX_API_KEY" ) values["scenex_api_key"] = scenex_api_key return values
[docs] def run(self, image: str) -> str: """运行SceneXplain图像解释器。""" description = self._describe_image(image) if not description: return "No description found." return description