搜索
首页后端开发Python教程如何构建可以使用任何网站的人工智能代理

将人工智能代理连接到网络:开发者的旅程和计算机使用的兴起

过去两年人工智能代理开发的一个主要障碍是可靠地授予网络访问权限。 考虑一个旨在发送电子邮件的 AI 代理:如何将其连接到 Gmail 或 Outlook? API、网站或自治网络代理?本文探讨了各种方法。

API 和 SDK:有限的方法

许多开发人员使用 API 和 SDK。这提供了低延迟和强大的身份验证,但存在限制:

  • API 不可用:并非所有 Web 服务都提供 API。
  • 文档挑战:过时或写得不好的文档很常见。
  • 功能差距: API 通常缺乏相应网站的完整功能,从而阻碍特定任务。

幸运的是,有几个服务提供 API 调用库:

  • Composio:为人工智能代理提供具有强身份验证的工具。
  • Langchain 工具:Langchain/图代理的资源。
  • Apify:一个庞大的社区驱动的 API 库。

但是,为了实现通用 Web 服务访问,我们必须超越 API。

网站互动:人性化的方法

可靠的人工智能代理网站交互可实现任何基于网络的人工任务的自动化。 但如何呢?

许多开发人员最初使用 Selenium 或 Playwright 等浏览器测试框架。 然而,这种方法面临着挑战:

  • 脆弱性:网站更改(例如 A/B 测试)很容易破坏脚本。
  • 可检测性:测试浏览器很容易识别和阻止。
  • 生产部署:托管浏览器、管理身份验证和轮换代理在生产中非常复杂。

为了解决这些问题,我们尝试了一个浏览器 SDK:

  1. 使用自然语言选择器(例如,get_element("find the login button"))而不是脆弱的 CSS 选择器。
  2. 集成内置身份验证。
  3. 提供预配置的远程托管和内置旋转代理以防止阻塞。

这项工作现已开源(Dendrite SDK),不再处于积极开发阶段,但仍然可供研究和改编。 类似的替代方案包括:

  • AgentQL:Python 库。
  • 舞台工作人员: JavaScript/TypeScript 库。

计算机使用:网络人工智能代理的未来?

Rich Sutton 的“惨痛教训”强调了可通过计算增加进行扩展的通用人工智能解决方案的主导地位。 Anthropic的Computer Use体现了这一原则,允许法学硕士使用鼠标和键盘输入直接控制计算机/浏览器,无需脚本和API调用。 他们的方法强调通用计算机技能而不是特定任务的工具。这与痛苦的教训完美契合,表明最通用的人工智能代理将像人类一样直接与网络交互。 早期结果显示,使用精心设计的提示(通常通过 Anthropic 的提示改进器来增强)在复杂任务中具有很高的可靠性。

结论:拥抱未来

虽然 API 仍然有价值,但未来可能有利于大多数 AI 代理使用类似计算机的方法。 如果代理可以登录并使用网站的搜索功能,从热门结果中提取结论,为什么还要通过 API 依赖整个数据库呢? 人工智能开发人员面临的问题是是否接受这种通用方法,还是面临更专业方法的局限性。

注意:这是我的第一个开发帖子。 欢迎提供有关改进未来帖子的反馈。 还鼓励提出有关人工智能代理或人工智能驱动的任务自动化的问题。 How to Build AI Agents that can Use any Website How to Build AI Agents that can Use any Website How to Build AI Agents that can Use any Website How to Build AI Agents that can Use any Website

以上是如何构建可以使用任何网站的人工智能代理的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python的执行模型:编译,解释还是两者?Python的执行模型:编译,解释还是两者?May 10, 2025 am 12:04 AM

pythonisbothCompileDIntered。

Python是按线执行的吗?Python是按线执行的吗?May 10, 2025 am 12:03 AM

Python不是严格的逐行执行,而是基于解释器的机制进行优化和条件执行。解释器将代码转换为字节码,由PVM执行,可能会预编译常量表达式或优化循环。理解这些机制有助于优化代码和提高效率。

python中两个列表的串联替代方案是什么?python中两个列表的串联替代方案是什么?May 09, 2025 am 12:16 AM

可以使用多种方法在Python中连接两个列表:1.使用 操作符,简单但在大列表中效率低;2.使用extend方法,效率高但会修改原列表;3.使用 =操作符,兼具效率和可读性;4.使用itertools.chain函数,内存效率高但需额外导入;5.使用列表解析,优雅但可能过于复杂。选择方法应根据代码上下文和需求。

Python:合并两个列表的有效方法Python:合并两个列表的有效方法May 09, 2025 am 12:15 AM

有多种方法可以合并Python列表:1.使用 操作符,简单但对大列表不内存高效;2.使用extend方法,内存高效但会修改原列表;3.使用itertools.chain,适用于大数据集;4.使用*操作符,一行代码合并小到中型列表;5.使用numpy.concatenate,适用于大数据集和性能要求高的场景;6.使用append方法,适用于小列表但效率低。选择方法时需考虑列表大小和应用场景。

编译的与解释的语言:优点和缺点编译的与解释的语言:优点和缺点May 09, 2025 am 12:06 AM

CompiledLanguagesOffersPeedAndSecurity,而interneterpretledlanguages provideeaseafuseanDoctability.1)commiledlanguageslikec arefasterandSecureButhOnderDevevelmendeclementCyclesclesclesclesclesclesclesclesclesclesclesclesclesclesclesclesclesclesandentency.2)cransportedeplatectentysenty

Python:对于循环,最完整的指南Python:对于循环,最完整的指南May 09, 2025 am 12:05 AM

Python中,for循环用于遍历可迭代对象,while循环用于条件满足时重复执行操作。1)for循环示例:遍历列表并打印元素。2)while循环示例:猜数字游戏,直到猜对为止。掌握循环原理和优化技巧可提高代码效率和可靠性。

python concatenate列表到一个字符串中python concatenate列表到一个字符串中May 09, 2025 am 12:02 AM

要将列表连接成字符串,Python中使用join()方法是最佳选择。1)使用join()方法将列表元素连接成字符串,如''.join(my_list)。2)对于包含数字的列表,先用map(str,numbers)转换为字符串再连接。3)可以使用生成器表达式进行复杂格式化,如','.join(f'({fruit})'forfruitinfruits)。4)处理混合数据类型时,使用map(str,mixed_list)确保所有元素可转换为字符串。5)对于大型列表,使用''.join(large_li

Python的混合方法:编译和解释合并Python的混合方法:编译和解释合并May 08, 2025 am 12:16 AM

pythonuseshybridapprace,ComminingCompilationTobyTecoDeAndInterpretation.1)codeiscompiledtoplatform-Indepententbybytecode.2)bytecodeisisterpretedbybythepbybythepythonvirtualmachine,增强效率和通用性。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中