Airtest核心API汇总

 

2024.2.25更新:新增剪切板、Airtest1.3.3touch/swipe支持绝对坐标和相对坐标

2023.9.3更新:Airtest1.2.7新增14个断言、断开连接API;Airtest1.2.10.2新增录屏API;

以下基于airtest1.2.0(截止2021.7.12,最新版本)
https://airtest.readthedocs.io/zh_CN/latest/all_module/airtest.core.api.html
修改自以上链接,并更新适配到airtest1.2.0版本,翻译了部分英文说明

想熟练使用Airtest,以下API必须熟记

1.init_device(platform='Android', uuid=None, **kwargs)
初始化设备,并设置为当前设备。

参数:
platform – Android, IOS or Windows
uuid     – 目标设备的uuid,例如Android的序列号,Windows的窗口句柄,或iOS的uuid
kwargs   – 可选的平台相关的参数,例如Android下的 cap_method=JAVACAP参数

返回:
device对象

示例:

 
  1. init_device(platform="Android",uuid="songzhenhua", cap_method="JAVACAP")

  2. init_device(platform="Windows",uuid="123456")


2.connect_device(uri)
用URI字符串来初始化设备,并且设置为当前设备。

参数:
uri – 一个用于初始化设备的URI字符串,例如:
android://adbhost:adbport/serialno?param=value&param2=value2

返回:
device对象

示例:

 
  1. # 本地安卓设备默认参数

  2. connect_device("Android:///")  

  3. # 本地安卓设备ID为:SJE5T17B17,且使用参数

  4. connect_device("Android:///SJE5T17B17?cap_method=javacap&touch_method=adb")

  5. # 远程安卓设备 Android://adbhost:adbport/serialno

  6. connect_device("Android://127.0.0.1:5037/10.254.60.1:5555")

  7. # connect to the desktop

  8. connect_device("Windows:///") 

  9. # Connect to the window with handle 123456 

  10. connect_device("Windows:///123456")  

  11. # iOS device

  12. connect_device("iOS:///127.0.0.1:8100")

  13. connect_device("iOS:///http://localhost:8100/?mjpeg_port=9100&&udid=00008020-001270842E88002E")  # iOS with mjpeg port and udid


3.device()
返回当前正在使用中的设备。

返回:
当前设备实例

示例:

 
  1. dev = device()

  2. dev.touch((100, 100))


4.set_current(idx)
设置当前设备。

参数:
idx – uuid或已初始化的设备列表中的编号,从0开始

引发:
IndexError – 当查找不到设备时

返回:
None

支持平台:
Android, iOS, Windows

示例:

 
  1. # 设置设备列表中的第1台设备为当前设备

  2. set_current(0)

  3. # 设置序列号为qasite的设备为当前设备

  4. set_current("qasite")


5.auto_setup(basedir=None, devices=None, logdir=None, project_root=None, compress=None)
自动配置运行环境,如果当前没有连接设备的话,就默认尝试连接Android设备。

参数:
basedir – 设置当前脚本的所在路径,也可以直接传 __file__ 变量进来
devices – 一个内容为 connect_device uri 字符串的列表
logdir  – 用于报告的日志目录,默认为None不输出日志, 设置为True时日志目录为/log
project_root – 用于设置PROJECT_ROOT变量,方便 using 接口的调用
compress – 屏幕截图的压缩比率,在[1, 99]范围内的整数,默认是10

示例:

 
  1. auto_setup(__file__)

  2. auto_setup(__file__, devices=["Android://127.0.0.1:5037/SJE5T17B17"],

  3.            logdir=True, project_root=r"D:\test\logs", compress=90)


6.shell(cmd)
在目标设备上运行远程shell指令

参数:
cmd – 需要在设备上运行的指令,例如 ls /data/local/tmp

返回:
shell指令的输出内容

支持平台:
Android

示例:

 
  1. # 在当前默认手机执行adb shell ls

  2. print(shell("ls"))

  3. # 在指定手机执行adb shell ls

  4. dev = connect_device("Android:///device1")

  5. dev.shell("ls")

  6. # 设置手机列表中的第1台手机为当前手机,并执行adb shell ls

  7. set_current(0)

  8. shell("ls")


7.start_app(package, activity=None)
在设备上启动目标应用

参数:
package  – 想要启动的应用包名package name,例如 com.netease.my
activity – 需要启动的activity,默认为None,意为main activity

返回:
None

支持平台:
Android, iOS

示例:

 
  1. start_app("com.netease.cloudmusic")

  2. start_app("com.apple.mobilesafari")  # on iOS


8.stop_app(package)
终止目标应用在设备上的运行

参数:
package – 需要终止运行的应用包名 package name,例如 com.netease.my

返回:
None

支持平台:
Android, iOS

示例:

 
  1. stop_app("com.netease.cloudmusic")


9.clear_app(package)
清理设备上的目标应用数据

参数:
package – 包名 package name,例如 com.netease.my

返回:
None

支持平台:
Android

示例:

 
  1. clear_app("com.netease.cloudmusic")


10.install(filepath, **kwargs)
安装应用到设备上

参数:
filepath – 需要被安装的应用路径(PC上的路径)
kwargs   – 平台相关的参数 kwargs,请参考对应的平台接口文档

返回:
None

支持平台:
Android, iOS

示例:

 
  1. install(r"D:\demo\qasite.apk")

  2. # adb install -r -t D:\demo\test.apk

  3. install(r"D:\demo\qasite.apk", install_options=["-r", "-t"])

  1. # iOS支持ipa包安装

  2. install(r"D:\demo\qasite.ipa") 

  3. # iOS也支持通过下载链接安装APP

  4. install("http://www.example.com/test.ipa") 


11.uninstall(package)
卸载设备上的应用

参数:
package – 需要被卸载的包名

返回:
None

支持平台:
Android, iOS

示例:

 
  1. uninstall("com.netease.cloudmusic")


12.snapshot(filename=None, msg="", quality=None, max_size=None)
对目标设备进行一次截图,并且保存到文件中。

参数:
filename – 保存截图的文件名,默认保存路径为 ST.LOG_DIR
msg      – 截图文件的简短描述,将会被显示在报告页面中
quality  – 图片的质量,[1,99]的整数,默认是10
max_size – 图片的最大尺寸,例如 1200

返回:
截图文件的绝对路径

支持平台:
Android, iOS, Windows

示例:

 
  1. snapshot(msg="index")

  2. # 设置保存文件名

  3. snapshot(filename="测试工程师小站.png", msg="test")

  4. #可以设置截图的画质和大小

  5. ST.SNAPSHOT_QUALITY = 30  # 设置截图质量为30

  6. ST.IMAGE_MAXSIZE = 600  # 设置最大尺寸不超过600*600

  7. # 此截图质量30,最大不超过600*600

  8. snapshot()  

  9. # 设置了全局参数,又额外设置单语句参数时,单语句优先,此截图质量90

  10. snapshot(filename="测试工程师小站.png", msg="test", quality=90)

  11. # 设置了全局参数,又额外设置单语句参数时,单语句优先,此截图最大不超1200*1200

  12. snapshot(filename="qasite.png", msg="test", quality=90, max_size=1200)


13.wake()
唤醒并解锁目标设备,在部分品牌手机上可能无法生效

返回:
None

支持平台:
Android

示例:

wake()

14.home()
返回HOME界面。

返回:
None

支持平台:
Android, iOS

示例:

home()

15.touch(v, times=1, **kwargs)
在当前设备画面上进行一次点击

参数:
v      – 点击位置,可以是一个 Template 图片实例,或是一个坐标(x,y)(相对坐标、绝对坐标均可)
times  – 点击次数
kwargs – 平台相关的参数 kwargs,请参考对应的平台接口文档

返回:
实际点击位置坐标 (x, y)

支持平台:
Android, Windows, iOS

示例:

 
  1. # 点击绝对坐标:

  2. touch((100, 100))

  1. # 点击相对坐标:

  2. touch((0.1, 0.1))

  1. # 点击图片的中心位置:

  2. touch(Template(r"测试工程师小站.png", target_pos=5))

  3. # 点击两次:

  4. touch((100, 100), times=2)

  5. # 在Android和Windows下,可以设置点击持续时间:

  6. touch((100, 100), duration=2)

  7. # 右键点击(Windows):

  8. touch((100, 100), right_click=True)


16.click(*args, **kwargs)
touch()的别名,一样


17.double_click(v)
双击

参数:
v – 点击位置,可以是一个 Template 图片实例,或是一个绝对坐标 (x, y)

返回:
实际点击位置坐标 (x, y)

示例:

 
  1. double_click((100, 100))

  2. double_click(Template(r"测试工程师小站.png"))


18.swipe(v1, v2=None, vector=None, **kwargs)
在当前设备画面上进行一次滑动操作。
有两种传入参数的方式

 
  1. swipe(v1, v2=Template(...)) # 从 v1 滑动到 v2

  2. swipe(v1, vector=(x, y)) # 从 v1 开始滑动,沿着vector方向。

参数:
v1 – 滑动的起点,可以是一个Template图片实例,或是坐标 (x, y)(相对坐标、绝对坐标均可)

v2 – 滑动的终点,可以是一个Template图片实例,或是坐标 (x, y)(相对坐标、绝对坐标均可)

vector – 滑动动作的矢量坐标,可以是绝对坐标 (x,y) 或是屏幕百分比,例如 (0.5, 0.5)
**kwargs – 平台相关的参数 kwargs,请参考对应的平台接口文档

引发:
Exception – 当没有足够的参数来执行滑动时引发异常

返回:
原点位置和目标位置

支持平台:
Android, Windows, iOS

示例:

 
  1. swipe(Template(r"测试工程师小站.png"), vector=[-0.0316, -0.3311])

  2. swipe((100, 100), (200, 200))

  3. #自定义滑动持续时间1s和经过6步到达终点:

  4. swipe((100, 100), (200, 200), duration=1, steps=6)


19.pinch(in_or_out='in', center=None, percent=0.5)
在设备屏幕上执行一个双指pinch捏合操作

参数:
in_or_out – 向内捏合或向外扩大,在[“in”, “out”] 中枚举一个值
center – pinch动作的中心位置,默认值为None则为屏幕中心点
percent – pinch动作的屏幕百分比,默认值为0.5

返回:
None

支持平台:
Android

示例:

 
  1. # 两指向屏幕中心点捏合:

  2. pinch()

  3. # 将(100, 100)作为中心点,向外扩张两指:

  4. pinch('out', center=(100, 100))


20.keyevent(keyname, **kwargs)
在设备上执行keyevent按键事件

参数:
keyname  – 平台相关的按键名称
**kwargs – 平台相关的参数 kwargs,请参考对应的平台接口文档

返回:
None

支持平台:
Android, Windows, iOS

示例:

 
  1. # 在Android上相当于执行了 adb shell input keyevent KEYNAME

  2. # 内部调用的android.adb.keyevent()

  3. # Android Keyevent详细文档:

  4. # https://developer.android.com/reference/android/view/KeyEvent#constants_1

  5. keyevent("HOME")

  6. keyevent("3")  # same as keyevent("HOME")

  7. keyevent("BACK")

  8. keyevent("KEYCODE_DEL")

  9. # 在Windows上内部调用的pywinauto.keyboard 进行按键点击

  10. # Windows Keyevent详细文档:

  11. # https://pywinauto.readthedocs.io/en/latest/code/pywinauto.keyboard.html

  12. keyevent("{DEL}")

  13. keyevent("%{F4}")  # close an active window with Alt+F4

  14. # iOS只支持 home/volumeUp/volumeDown:

  15. keyevent("HOME")

  16. keyevent("volumeUp")


21.text(text, enter=True, **kwargs)
在目标设备上输入文本,文本框需要处于激活状态。

参数:
text  – 要输入的文本
enter – 是否在输入完毕后,执行一次 Enter ,默认是True

返回:
None

支持平台:
Android, Windows, iOS

示例:

 
  1. text("公众号:测试工程师小站") # 输入完毕后点回车

  2. text("公众号:测试工程师小站", enter=False)

  3. # 在Android上,有时你需要在输入完毕后点击搜索按钮:

  4. text("公众号:测试工程师小站", search=True)

  5. # 如果希望输入其他按键,可以用这个接口, code详情:

  6. # https://developer.android.com/reference/android/view/inputmethod/EditorInfo.html#constants_1

  7. text("公众号:测试工程师小站")

  8. device().yosemite_ime.code("3")  # 3 = IME_ACTION_SEARCH


22.sleep(secs=1.0)
设置一个等待sleep时间,它将会被显示在报告中

参数:
secs – sleep的时长

返回:
None

支持平台:
Android, Windows, iOS

示例:

sleep(1)

23.wait(v, timeout=None, interval=0.5, intervalfunc=None)
等待当前画面上出现某个匹配的Template图片

参数:
v – 要等待出现的目标Template实例
timeout – 等待匹配的最大超时时长,默认为None即默认取 ST.FIND_TIMEOUT 的值
interval – 尝试查找匹配项的时间间隔(以秒为单位)
intervalfunc – 在首次尝试查找匹配失败后的回调函数

引发:
TargetNotFoundError – 在超时后仍未找到目标则触发

返回:
匹配目标的坐标

支持平台:
Android, Windows, iOS

示例:

 
  1. wait(Template(r"测试工程师小站.png"))  # timeout after ST.FIND_TIMEOUT

  2. # 每3秒查找一次, 120秒超时

  3. wait(Template(r"测试工程师小站.png"), timeout=120, interval=3)

  4. # 你可以在每次查找目标失败时,指定一个回调函数:

  5. def notfound():

  6.     print("No target found")

  7. wait(Template(r"测试工程师小站.png"), intervalfunc=notfound)


24.exists(v)
检查设备上是否存在给定目标

参数:
v – 要检查的目标

返回:
如果未找到目标,则返回False,否则返回目标的坐标

支持平台:
Android, Windows, iOS

示例:

 
  1. if exists(Template(r"测试工程师小站.png")):

  2.     touch(Template(r"测试工程师小站.png"))

  3. # 因为 exists() 会返回坐标,我们可以直接点击坐标来减少一次图像查找

  4. pos = exists(Template(r"测试工程师小站.png"))

  5. if pos:

  6.     touch(pos)


25.find_all(v)
在设备屏幕上查找所有出现的目标并返回其坐标列表

参数:
v – 寻找目标

返回:
结果列表

[{‘result’: (x, y), ‘rectangle’: ( (left_top, left_bottom, right_bottom, right_top) ), ‘confidence’: 0.9}, …]

支持平台:
Android, Windows, iOS

示例:

 
  1. find_all(Template(r"测试工程师小站.png"))

  2. [{'result': (218, 468), 'rectangle': ((149, 440), (149, 496), (288, 496), (288, 440)),'confidence': 0.9999996423721313}]


26.assert_exists(v, msg="")
设备屏幕上存在断言目标

参数:
v   – 要检查的目标
msg – 断言的简短描述,它将被记录在报告中

引发:
AssertionError – 如果断言失败

返回:
目标坐标

支持平台:
Android, Windows, iOS

示例:

assert_exists(Template(r"测试工程师小站.png"), "assert exists")

27.assert_not_exists(v, msg="")
设备屏幕上不存在断言目标

参数:
v   – 要检查的目标
msg – 断言的简短描述,它将被记录在报告中

引发:
AssertionError – 如果断言失败

返回:
None.

支持平台:
Android, Windows, iOS

示例:

assert_not_exists(Template(r"测试工程师小站.png"), "assert not exists")

28.assert_equal(first, second, msg="")
断言两个值相等

参数:
first  – 第一个值
second – 第二个值
msg    – 断言的简短描述,它将被记录在报告中

引发:
AssertionError – 如果断言失败

返回:
None

支持平台:
Android, Windows, iOS

示例:

assert_equal(1, 1, msg="assert 1==1")

29.assert_not_equal(first, second, msg="")
断言两个值不相等

参数:
first  – 第一个值
second – 第二个值
msg    – 断言的简短描述,它将被记录在报告中

引发:
AssertionError – 如果断言异常

返回:
None

支持平台:
Android, Windows, iOS

示例:

assert_not_equal(1, 2, msg="assert 1!=2")

30.Airtest1.2.7新增14个断言

都是基于assert衍生出来的,这里就不过多介绍了,详细可看

Airtest1.2.7新增的14个断言API解析

 
  1. assert_true

  2. assert_false

  3. assert_is

  4. assert_is_not

  5. assert_is_none

  6. assert_is_not_none

  7. assert_in

  8. assert_not_in

  9. assert_is_instance

  10. assert_not_is_instance

  11. assert_greater

  12. assert_greater_equal

  13. assert_less

  14. assert_less_equal


31.start_recording()
开始录屏

参数

由于Android和iOS参数有细微差别,就不再列出,详细用法可看:

Airtest1.2.10.2版本Android录屏功能

Airtest新增iOS、Windows录屏功能,真香!

示例
 
  1. dev = device()

  2. save_path = dev.start_recording(output="test.mp4")

  3. sleep(30)

  4. dev.stop_recording()


32.stop_recording()
结束录屏


33.disconnect()
airtest1.2.7新增接口,主要是解决脚本长时间运行,反复切换横屏和竖屏应用时,会有概率 出现屏幕有一半内容变成黑屏 的问题。
使用方法为在脚本最后添加device().disconnect(),让设备创建出的所有adb连接都强制释放掉。
最好是用在try…except…finally,写在finally里面,这样即使失败也会清理


34.set_clipboard(content)
设置剪切板内容

参数:
content– 要设置的内容

支持平台:
Android, Windows, iOS


35.get_clipboard()
获取剪切板内容

返回:
剪切板内容

支持平台:
Android, Windows, iOS

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

  1. 文档获取方式:

  2. 加入我的软件测试交流群:680748947免费获取~(同行大佬一起学术交流,每晚都有大佬直播分享技术知识点)

这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/626301.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

如何将公众号添加到CSDN个人主页

1. 创作中心- 推广管理 输入个人公众号名字并开启微信公众号推广 2. 将公众号的二维码图片加入拓展信息 个人主页的左下角就能看到推广 如果希望能看到是二维码 操作如下: 写篇文章贴上二维码 然后点击鼠标右键获得此页面链接 ,例如我的个人公众号 htt…

洗地机哪款好用?希亦、追觅、顺造、米家等高品质洗地机推荐

家用洗地机已经成为家庭清洁的重要利器,其多功能性能帮助您轻松应对各种清洁任务,从而保持家居环境的清洁整洁。然而,市场上品牌繁多、功能各异的洗地机让人眼花缭乱。为了帮助大家做出明智的选择,我们将在本文中提供全面的选购指…

力扣98.验证二叉搜索树

法一(自己思路,复杂了): from collections import dequeclass Solution(object):def isValidBST(self, root):""":type root: TreeNode:rtype: bool"""queue deque()if root.left!None:queue.app…

凸优化理论学习三|凸优化问题(一)

系列文章目录 凸优化理论学习一|最优化及凸集的基本概念 凸优化理论学习二|凸函数及其相关概念 文章目录 系列文章目录一、优化问题(一)标准形式的优化问题(二)可行点和最优点(三)局部最优点(四…

地平线X3开发板Intel Realsense深度相机调试记录

1. 预编译包 编译这个SDK花费了5.6个小时,为了方便各位后续使用, 各位可以直接下载编译好的文件,包含C和Python的库,相关文件已经上传至百度云(提取码:awe4 )。 在提供的这些文件中&#xf…

思科模拟器学习1--Vlan Trunk

实验说明:将三台电脑的vlan 加到一台交换机里面,为了验证什么是虚拟局域网,把一个设备隔成三个空间,三个电脑互相不能通讯;目的是:vlan 1的通讯不可以向vlan 2传送,就是消息传送互不干扰的&…

独家揭秘:亲历清华大学答辩现场,惊喜万分 名校答辩不简单

会议之眼 快讯 五月,对于学术界来说,迎来了答辩的高潮!是收获的季节!今天,趁着阳光明媚,小编怀揣着对学术探索的无限热情和好奇心,决定亲自踏入中国顶尖学术殿堂——清华大学深圳国际研究生院&…

【核弹】我的第一款IDEA插件

SuperHotSwap 插件名称叫做:SuperHotSwap(超级热更新) 开发初心:旨在做出一款最便捷的IDEA热更新插件,减少用户操作步骤,提供零配置的可视化操作更新。 为什么要写这个插件: 每次改一下Mappe…

Linux内核发送网络数据

前言 我们开始今天对 Linux 内核⽹络发送过程的深度剖析。还是按照我们之前的传统,先从⼀段代码作为切⼊。 上述代码中,调⽤ send 之后内核是怎么样把数据包发送出去的。本⽂基于Linux 3.10,⽹卡驱动采⽤Intel的igb举例。 基础框架 我们看…

08 必会框架 - Spring全家桶

本课时主要介绍 Java 中常用的应用框架,重点讲解如下三部分内容。 Spring 框架中的主要知识点; NIO 框架 Netty 以及基于 Netty 实现的主流 RPC 框架 Motan、Dubbo 和 gRPC; ORM 框架 MyBatis。 常用框架汇总 先来看常用框架的知识点汇总…

AuroraFOC使用指南一(STM32F405双路FOC)

一. 简介 哈喽,感谢各位选择AuroraFOC开发板,在这里将对其进行一个详细的介绍,方便大家使用。并且对提供的工程文件和上位机的操作也进行了详细的说明。 有什么疑问或者好的建议 可以微信联系: WU1356742146 最后再次感谢大家的支持。 Aur…

番外篇 | 手把手教你利用YOLOv8进行热力图可视化 | 针对视频

前言:Hello大家好,我是小哥谈。YOLOv8的热力图可视化可以帮助我们更加直观地了解模型在图像中的检测情况,同时也可以帮助我们进行模型的调试和优化。热力图是一种颜色渐变的图像,不同颜色的区域表示不同程度的关注度或者置信度。在YOLOv8中,可以通过设置阈值来控制热力图的…

产品品牌CRUD

文章目录 1.renren-generator生成CRUD1.数据库表设计1.数据表设计2.分析 2.代码生成器生成crud1.查看generator.properties(不需要修改)2.修改application.yml 连接的数据库修改为云数据库3.启动renren-generator模块4.浏览器访问 http://localhost:81/5…

能聚合各站热点的DailyHot

什么是 DailyHot ? 今日热榜(DailyHot)是一个获取各大热门网站热门头条的聚合网站,能追踪全网热点、实现简单高效阅读。项目分为前、后端,其中后端提供了一个聚合热门数据的 API 接口。 🚩 后端 API 特性 极快响应&a…

vue3+ts(<script setup lang=“ts“>)刷新页面后保持下拉框选中效果

效果图&#xff1a; 代码&#xff1a; <template><div class"app-layout"><div class"app-box"><div class"header"><div class"header-left"></div><div class"title">室外智…

css实现围绕中心进行圆形旋转

效果如下 通过css animation属性能实现以上效果 先试用定位&#xff0c;将每一项设置一个初始位置 {cursor: pointer;left: 50%;width: 144px;height: 144px;display: flex;align-items: center;justify-content: center;margin-left: -72px;top: 228px;position: absolute;a…

Cesium 3DTileset Style 原理简析

Cesium 3DTileset Style 原理简析 应用层会看到这样的使用。那么原理是什么, 为啥写 height, 除了这个还有啥? const tileset await Cesium.Cesium3DTileset.fromUrl("../../public/tileset/building/tileset.json"); tileset.style new Cesium.Cesium3DTileSty…

【基本数据结构】链表

文章目录 前言链表简介头节点与尾节点特性 分类单向链表双向链表循环链表 单链表基本操作定义并初始化单链表读取节点插入节点删除节点修改节点 参考资料写在最后 前言 本系列专注更新基本数据结构&#xff0c;现有以下文章&#xff1a; 【算法与数据结构】数组. 【算法与数…

Python 操作数据库

十、Python3 操作数据库 1、Python3 操作 MySQL 1、基本介绍 Python3 操作 MySQL 数据库 可以使用的模块是 pymysql 和 MySQLdb。 这个两个模块都是通过自己的 API 执行原生的 SQL 语句实现的。 MySQLdb 是最早出现的一个操作 MySQL 数据库的模块&#xff0c;核心由C语言编…

LangChain-Chatchat 实践

1. 说明 比较了几个AI LLM的集成应用工具(比如Quivr, Dify, one-api), 还是LangChain-Chatchat更符合我的需要: 支持私有化部署不同的LLM知识库支持Api支持开源免费, 容易二开 相关路径: 条项路径LangChain-Chatchat 项目/data0/Projects/Langchain-ChatchatLLM 语言模型保…