Tool - DuckDuckGoSearch

基本介绍

DuckDuckGo 搜索工具是 Tool InvokableTool 接口的一个实现,用于通过 DuckDuckGo 搜索引擎进行网络搜索,DuckDuckGo 是一个注重隐私的搜索引擎,不会追踪用户的搜索行为,重点是无需 api key 鉴权即可直接使用。该组件实现了 Eino: ToolsNode 使用说明

使用方式

组件初始化

DuckDuckGo 搜索工具通过 NewTool 函数进行初始化,主要配置参数如下:

tool, err := NewTool(ctx, &Config{
    ToolName:    "duckduckgo_search",     // 工具名称
    ToolDesc:    "search web for information by duckduckgo", // 工具描述
    Region:      ddgsearch.RegionWT,      // 搜索地区
    MaxResults:  10,                      // 每页结果数量
    SafeSearch:  ddgsearch.SafeSearchOff, // 安全搜索级别
    TimeRange:   ddgsearch.TimeRangeAll,  // 时间范围
    DDGConfig:   &ddgsearch.Config{},     // DuckDuckGo 配置
})

搜索参数

搜索请求支持以下参数:

type SearchRequest struct {
    Query string `json:"query"` // 搜索关键词
    Page  int    `json:"page"`  // 页码
}

完整使用示例

package main

import (
    "context"
    
    "github.com/cloudwego/eino-ext/components/tool/duckduckgo"
    "github.com/cloudwego/eino-ext/components/tool/duckduckgo/ddgsearch"
)

func main() {
    ctx := context.Background()
    
    // 初始化搜索工具
    searchTool, err := duckduckgo.NewTool(ctx, &duckduckgo.Config{
        Region:     ddgsearch.RegionWT,
        MaxResults: 10,
        SafeSearch: ddgsearch.SafeSearchOff,
        TimeRange:  ddgsearch.TimeRangeAll,
    })
    if err != nil {
        panic(err)
    }
    
    // 准备搜索请求
    request := &SearchRequest{
        Query: "Golang concurrent programming",
        Page:  1,
    }
    
    // 执行搜索
    result, err := searchTool.Search(ctx, request)
    if err != nil {
        panic(err)
    }
    
    // 处理搜索结果
    println(result) // JSON 格式的搜索结果
}

搜索结果示例

{
    "results": [
        {
            "title": "Go 并发编程实践",
            "description": "这是一篇关于 Go 语言并发编程的文章...",
            "link": "https://example.com/article1"
        },
        {
            "title": "Understanding Concurrency in Go",
            "description": "A comprehensive guide to concurrent programming...",
            "link": "https://example.com/article2"
        }
    ]
}

相关文档


最后修改 January 13, 2025 : docs: add description for streamx (#1202) (0337c81)