摘要:def extract_website_data(website_screenshot_path: str):"""Extract data from a website screenshot.Args:website_screenshot_path (str
DSPy 最近在测试版中增加了对 VLM 的支持。本文介绍使用 DSPy 从图像中提取属性。对于此示例,我们将了解如何从网站屏幕截图中提取有用的属性
定义DSPy签名。注意 dspy.Image 输入字段:
import dspyclass WebsiteDataExtractionSignature(dspy.Signature):"""Website data extraction"""website_screenshot: dspy.Image = dspy.InputField(desc="A screenshot of the website")hero_text: str = dspy.OutputField(desc="The hero text of the website")website_description: str = dspy.OutputField(desc="A description of the website")call_to_action: str = dspy.OutputField(desc="The call to action of the website")color_palette: list[str] = dspy.OutputField(desc="The color palette of the website")font_palette: list[str] = dspy.OutputField(desc="The font palette of the website")2、定义模块接下来使用 ChainOfThought 优化器和上一步中的签名定义一个简单的程序:
class WebsiteDataExtraction(dspy.Module):"""Module for extracting structured data from website screenshots."""def __init__(self):self.website_data_extraction = dspy.ChainOfThought(WebsiteDataExtractionSignature)# pylint: disable=missing-function-docstringdef forward(self, website_screenshot: str):website_data = self.website_data_extraction(website_screenshot)return website_data3、最终代码最后,编写一个函数来读取图像并通过调用上一步中的程序来提取属性:
def extract_website_data(website_screenshot_path: str):"""Extract data from a website screenshot.Args:website_screenshot_path (str): Path to the website screenshot imageReturns:dict: Extracted website data"""# Load the imagewith open(website_screenshot_path, "rb") as image_file:base64_data = base64.b64encode(image_file.read).decode('utf-8').replace('\n', '')image_data_uri = f"data:image/png;base64,{base64_data}"website_data_extraction = WebsiteDataExtractionwebsite_data = website_data_extraction(image_data_uri)return website_dataif __name__ == "__main__":dspy_lm = dspy.LM(model="openai/gpt-4o-mini")dspy.config( lm=dspy_lm)result = extract_website_data("src/vision_lm/data/langtrace-screenshot.png")print(result)4、可观察性来源:梳美教育
免责声明:本站系转载,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与本站联系,我们将在第一时间删除内容!