Skip to main content
@langchain/google 包支持 Gemini 的内置工具,这些工具提供了诸如网络搜索增强、代码执行、URL 上下文检索等功能。这些工具作为 Gemini 原生对象,通过 bindTools()tools 调用选项传递给 ChatGoogle
在同一请求中,不能混合使用 Gemini 原生工具(Google 搜索、代码执行等)和标准的 LangChain 工具(基于 Zod 的函数工具)。关于标准工具调用的用法,请参阅 ChatGoogle 页面。

Google 搜索

googleSearch 工具使用实时的 Google 搜索结果来增强模型的响应。这对于关于当前事件或特定事实的问题非常有用。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      googleSearch: {},
    },
  ]);

const res = await llm.invoke("谁赢得了最近的世界大赛?");
console.log(res.text);
你可以选择性地将搜索结果过滤到特定的时间范围:
const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
  {
    googleSearch: {
      timeRangeFilter: {
        startTime: "2025-01-01T00:00:00Z",
        endTime: "2025-12-31T23:59:59Z",
      },
    },
  },
]);
googleSearchRetrieval 工具为向后兼容而保留,但推荐使用 googleSearch
更多信息,请参阅 Google 的“使用 Google 搜索进行增强”文档

代码执行

codeExecution 工具允许 Gemini 生成并运行 Python 代码来解决复杂问题。模型编写代码、执行代码并返回结果。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      codeExecution: {},
    },
  ]);

const res = await llm.invoke("计算第 100 个斐波那契数。");
console.log(res.contentBlocks);
响应在 contentBlocks 字段中同时包含生成的代码及其执行结果:
for (const block of res.contentBlocks) {
  if (block.type === "tool_code") {
    console.log("代码:", block.toolCode);
  } else if (block.type === "tool_result") {
    console.log("结果:", block.toolResult);
  }
}
更多信息,请参阅 Google 的代码执行文档

URL 上下文

urlContext 工具允许 Gemini 从 URL 获取内容并使用这些内容来增强其响应。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      urlContext: {},
    },
  ]);

const res = await llm.invoke("总结这个页面:https://js.langchain.com/");
console.log(res.text);
更多信息,请参阅 Google 的 URL 上下文文档

Google 地图

googleMaps 工具使用来自 Google 地图的地理空间上下文来增强响应。这对于与地点相关的查询非常有用。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      googleMaps: {},
    },
  ]);

const res = await llm.invoke("时代广场附近最好的咖啡店有哪些?");
console.log(res.text);
你可以启用小部件上下文令牌来渲染 Google 地图小部件:
const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      googleMaps: {
        enableWidget: true,
    },
  },
]);

const res = await llm.invoke("找到芝加哥市中心的意大利餐厅");

// 从增强元数据中访问小部件上下文令牌
const groundingMetadata = res.response_metadata?.groundingMetadata;
console.log(groundingMetadata?.googleMapsWidgetContextToken);
更多信息,请参阅 Google 的“使用 Google 地图进行增强”文档

文件搜索

fileSearch 工具从文件搜索存储中执行语义检索。文件必须首先使用 Gemini 文件 API 导入。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      fileSearch: {
      fileSearchStoreNames: ["fileSearchStores/my-store-123"],
    },
  },
]);

const res = await llm.invoke("报告关于第四季度收入说了什么?");
console.log(res.text);
配置选项:
  • fileSearchStoreNames (必需) — 要从中检索的文件搜索存储的名称
  • metadataFilter (可选) — 应用于检索的元数据过滤器
  • topK (可选) — 要返回的语义检索块的数量
更多信息,请参阅 Google 的文件搜索文档

计算机使用

computerUse 工具使 Gemini 能够与浏览器环境交互。模型可以查看屏幕截图并执行点击、输入、滚动等操作。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      computerUse: {
      environment: "ENVIRONMENT_BROWSER",
    },
  },
]);
配置选项:
  • environment (必需) — 正在操作的环境(例如 "ENVIRONMENT_BROWSER"
  • excludedPredefinedFunctions (可选) — 要从操作空间中排除的预定义函数
更多信息,请参阅 Google 的计算机使用文档

MCP 服务器

mcpServers 字段允许 Gemini 连接到远程 MCP(模型上下文协议)服务器。与其他原生工具不同,MCP 服务器在工具对象上指定为一个数组。
import { ChatGoogle } from "@langchain/google";

const llm = new ChatGoogle("gemini-2.5-flash")
  .bindTools([
    {
      mcpServers: [
      {
        name: "my-mcp-server",
        streamableHttpTransport: {
          url: "https://my-mcp-server.example.com/mcp",
        },
      },
    ],
  },
]);

const res = await llm.invoke("使用 MCP 服务器中的工具来帮助我。");
console.log(res.text);
更多信息,请参阅 Google 的 MCP 文档

Vertex AI Search 数据存储

如果你正在使用 Vertex AI (platformType: "gcp"),你可以使用 Vertex AI Search 数据存储来增强响应。
import { ChatGoogle } from "@langchain/google";

const projectId = "YOUR_PROJECT_ID";
const datastoreId = "YOUR_DATASTORE_ID";

const llm = new ChatGoogle({
  model: "gemini-2.5-pro",
  platformType: "gcp",
}).bindTools([
  {
    retrieval: {
      vertexAiSearch: {
        datastore: `projects/${projectId}/locations/global/collections/default_collection/dataStores/${datastoreId}`,
      },
      disableAttribution: false,
    },
  },
]);

const res = await llm.invoke(
  "阿根廷对玻利维亚足球比赛的比分是多少?"
);
console.log(res.text);
更多信息,请参阅 Google 的“使用 Vertex AI Search 进行增强”文档