嵌入模型与Chroma向量数据库 - Chroma 集合查询操作 - AI大模型应用开发必备知识
大家好我是小锋老师最近更新《2027版 1天学会 嵌入模型与Chroma向量数据库 AI大模型应用开发 必备知识 视频教程》专辑感谢大家支持。本课程主要介绍和讲解嵌入模型与向量数据库简介Qwen3嵌入模型使用Chroma向量数据库使用Chroma安装Client-Server模式集合添加修改删除查询操作以及自定义Embedding Functions。视频教程课件源码打包下载链接https://pan.baidu.com/s/1Oo7dtFf_Zt7hJyl6aYX6TA?pwd1234提取码1234嵌入模型与Chroma向量数据库 - Chroma 集合查询操作 - AI大模型应用开发必备知识查询Query API支持在稠密嵌入上进行最近邻相似性搜索。当您想要检索记录而不进行相似性排名时请使用获取Get API。Query您可以使用 .query 查询集合以运行相似性搜索collection.query( query_texts[thus spake zarathustra, the oracle speaks] )Chroma将使用该集合的嵌入功能来嵌入您的文本查询并使用输出结果对您的集合进行向量相似性搜索。 你可以直接提供query_embeddings而不是query_texts。如果你的集合没有附加嵌入函数则必须这样做。你的查询嵌入的维度必须与集合中嵌入的维度相匹配。 Python还支持将query_images和query_uris作为查询输入。collection.query( query_embeddings[[11.1, 12.1, 13.1], [1.1, 2.3, 3.2]] )默认情况下Chroma每次输入查询会返回10个结果。您可以使用n_results参数来修改这个数字collection.query( query_embeddings[[11.1, 12.1, 13.1], [1.1, 2.3, 3.2]], n_results100 )ids参数允许您将搜索范围限制在仅包含所提供列表中ID的记录collection.query( query_embeddings[[11.1, 12.1, 13.1], [1.1, 2.3, 3.2]], n_results100, ids[id1, id2] )查询和获取支持其中where用于元数据过滤where_document用于全文搜索regex用于正则表达式collection.query( query_embeddings[[11.1, 12.1, 13.1], [1.1, 2.3, 3.2]], n_results100, where{page: 10}, # query records with metadata field page equal to 10 where_document{$contains: search string} # query records with the search string in the records document )Get使用.get方法通过ID和/或过滤器检索记录无需进行相似度排序collection.get(ids[id1, id2]) # by IDs ​ collection.get(limit100, offset0) # with paginationquery和get实例import chromadb chroma_client chromadb.Client() # 创建Chroma客户端 ​ collection chroma_client.create_collection(namemy_collection) ​ # 添加 collection.add( ids[id1, id2, id3], documents[lorem ipsum..., doc2, doc3], metadatas[{chapter: 3, verse: 16}, {chapter: 3, verse: 5}, {chapter: 29, verse: 11}], ) ​ # query查询 results collection.query( query_texts[doc], where{chapter: 3} ) print(results) ​ # get查询 results collection.get(ids[id1, id3]) print(results)运行输出查询返回结果格式定制Chroma以列优先的形式返回.query和.get结果每个字段一个数组。.query结果按输入查询进行分组.get结果为记录的扁平列表。class QueryResult(TypedDict): ids: List[IDs] embeddings: Optional[List[Embeddings]] documents: Optional[List[List[Document]]] uris: Optional[List[List[URI]]] metadatas: Optional[List[List[Metadata]]] distances: Optional[List[List[float]]] included: Include ​ class GetResult(TypedDict): ids: List[ID] embeddings: Optional[Embeddings] documents: Optional[List[Document]] uris: Optional[URIs] metadatas: Optional[List[Metadata]] included: Include在 Get 操作的结果中每个数组中的对应元素都属于同一个文档。# 设置GET返回结果格式 print(设置GET返回结果格式) result collection.get(include[documents, metadatas]) for id, document, metadata in zip(result[ids], result[documents], result[metadatas]): print(id, document, metadata)运行输出Query是一个批处理API返回按输入分组的结果。一种常见模式是遍历每个查询的“批处理”结果然后在该批处理结果内进行迭代。# 设置QUERY返回结果格式 print(设置QUERY返回结果格式) result collection.query(query_texts[doc]) for ids, documents, metadatas in zip(result[ids], result[documents], result[metadatas]): for id, document, metadata in zip(ids, documents, metadatas): print(id, document, metadata)运行输出设置返回数据默认情况下Query返回文档、元数据和距离而Get返回文档和元数据。使用include来控制返回的内容。id始终会被返回。collection.query( query_texts[my query], include[documents, metadatas, embeddings], ) ​ collection.get(include[documents])完整实例import chromadb chroma_client chromadb.Client() # 创建Chroma客户端 ​ collection chroma_client.create_collection(namemy_collection) ​ # 添加 collection.add( ids[id1, id2, id3], documents[doc1, doc2, doc3], metadatas[{chapter: 3, verse: 16}, {chapter: 3, verse: 5}, {chapter: 29, verse: 11}], ) ​ # query查询 results collection.query( query_texts[doc] ) print(results) ​ results collection.query( query_texts[doc], include[documents, metadatas, embeddings], ) print(results) ​ results collection.get(include[documents]) print(results)运行输出{ids: [[id1, id2, id3]], embeddings: None, documents: [[doc1, doc2, doc3]], uris: None, included: [metadatas, documents, distances], data: None, metadatas: [[{chapter: 3, verse: 16}, {chapter: 3, verse: 5}, {chapter: 29, verse: 11}]], distances: [[0.43373435735702515, 0.45694848895072937, 0.46765562891960144]]} {ids: [[id1, id2, id3]], embeddings: [array([[-0.08946741, 0.02690166, 0.0714293 , ..., 0.02614263, 0.07775341, 0.04677901], [-0.05917228, 0.03088627, 0.05787703, ..., 0.07566307, 0.06910366, 0.04536708], [-0.071605 , 0.01184757, 0.01126055, ..., 0.04132259, 0.06954481, 0.04966979]], shape(3, 384))], documents: [[doc1, doc2, doc3]], uris: None, included: [documents, metadatas, embeddings], data: None, metadatas: [[{chapter: 3, verse: 16}, {verse: 5, chapter: 3}, {verse: 11, chapter: 29}]], distances: None} {ids: [id1, id2, id3], embeddings: None, documents: [doc1, doc2, doc3], uris: None, included: [documents], data: None, metadatas: None}

相关新闻

日本数学教育家“dy/dx不是分数”谬论使学生不能正确认识导数概念

日本数学教育家“dy/dx不是分数”谬论使学生不能正确认识导数概念

黄小宁 学习不能满足于只知结论不懂原理的低层次浅薄。在解微分方程时为什么能将“不是分式的数学表达式”看成是分式?理论依据是什么? 高等数学是研究变量的 ,两变量之间可有除法运算。两非0无穷小变量之间就有除法运算,例无穷…

2026/5/17 7:23:11 阅读更多 →
别再瞎找了!降AIGC软件 千笔·降AIGC助手 VS 学术猹,本科生专属神器!

别再瞎找了!降AIGC软件 千笔·降AIGC助手 VS 学术猹,本科生专属神器!

在AI技术快速发展的今天,越来越多的本科生开始借助AI工具辅助论文写作,提升效率、优化内容。然而,随着学术查重系统对AI生成内容的识别能力不断提升,论文中“AI痕迹”过重的问题愈发突出,不仅影响查重率,更…

2026/7/5 2:32:25 阅读更多 →
工程建筑行业如何通过WebUploader+PHP实现BIM模型文件的分片传输?

工程建筑行业如何通过WebUploader+PHP实现BIM模型文件的分片传输?

大文件上传方案设计与实现(政府信创环境兼容) 方案背景 作为北京某软件公司的开发人员,我负责为政府客户实现一个兼容主流浏览器和信创国产化环境的大文件上传系统。当前需求是支持4GB左右文件的上传,后端使用PHP,前…

2026/7/5 18:05:50 阅读更多 →

最新新闻

中小教培机构到底该怎么选管理系统?一个12年运营顾问掏心窝建议

中小教培机构到底该怎么选管理系统?一个12年运营顾问掏心窝建议

教培机构为什么总是管不好账、留不住人? 做了12年校区运营咨询,我见过太多中小机构死在"管理"两个字上。不是课上得不好,是排课冲突、续费提醒漏发、课时算不清、家长投诉没人接——这些琐碎的事,一点点把校长的精力吃…

2026/7/6 1:49:40 阅读更多 →
线结构光标定精度对比:棋盘格法 vs 平面法向量法,3种中心线提取算法实测

线结构光标定精度对比:棋盘格法 vs 平面法向量法,3种中心线提取算法实测

线结构光标定精度对比:棋盘格法 vs 平面法向量法,3种中心线提取算法实测在工业检测、逆向工程和机器人引导等领域,高精度三维测量技术发挥着关键作用。线结构光技术因其非接触、高效率和高精度的特点,成为三维测量的重要手段。然而…

2026/7/6 1:47:40 阅读更多 →
温州大学机器学习课程开源项目全解析:从环境搭建到算法实战的保姆级学习指南

温州大学机器学习课程开源项目全解析:从环境搭建到算法实战的保姆级学习指南

温州大学机器学习课程开源项目全解析:从环境搭建到算法实战的保姆级学习指南 在人工智能技术日新月异的今天,机器学习已成为计算机科学领域最热门的方向之一。对于初学者而言,面对浩如烟海的算法理论和复杂的数学推导,往往感到无从…

2026/7/6 1:45:39 阅读更多 →
Java设计模式——结构型

Java设计模式——结构型

设计模式:结构型模式结构型模式关注的是:类和对象之间如何组合,如何让系统结构更灵活、更容易扩展。 创建型模式解决“对象怎么创建”,结构型模式解决“对象怎么组装”。一、结构型模式总览结构型模式主要解决以下问题&#xff1a…

2026/7/6 1:45:39 阅读更多 →
震散机自动化厂家技术能力与设备可靠性分析

震散机自动化厂家技术能力与设备可靠性分析

在化肥、化工、食品等行业的物料处理环节中,原料因长期堆放产生的板结问题,一直是影响生产效率和产品质量的常见痛点。传统的处理方式多依赖人工敲袋或外部机械破碎,不仅劳动强度大、效率低,而且容易损坏包装袋和内衬膜&#xff0…

2026/7/6 1:43:39 阅读更多 →
事件通道:EventChannel实现原生向ArkTS推送数据(102)

事件通道:EventChannel实现原生向ArkTS推送数据(102)

一、 ArkTS 侧:创建通道并监听事件在 ArkTS 侧,首先需要创建一个 EventChannel 实例,并设置消息监听器。当原生层推送数据时,监听器会被触发。核心代码示例(ArkTS):import bridge from arkui-x.…

2026/7/6 1:41:38 阅读更多 →

日新闻

H2 与 MySQL 单元测试兼容性:5 个关键 SQL 语句差异与规避方案

H2 与 MySQL 单元测试兼容性:5 个关键 SQL 语句差异与规避方案

H2与MySQL单元测试兼容性:5个关键SQL语句差异与规避方案1. 单元测试中的数据库兼容性挑战在Java开发领域,单元测试是保证代码质量的重要环节。当应用涉及数据库操作时,测试环境的搭建往往成为开发者的痛点。H2数据库因其轻量级、内存模式和快…

2026/7/6 0:01:17 阅读更多 →
Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘

Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘

Windows任务栏终极清理指南:用RBTray一键隐藏窗口到系统托盘 【免费下载链接】rbtray A fork of RBTray from http://sourceforge.net/p/rbtray/code/. 项目地址: https://gitcode.com/gh_mirrors/rb/rbtray 你是否厌倦了Windows任务栏上密密麻麻的图标&…

2026/7/6 0:01:17 阅读更多 →
Visual C++ 运行时库一键安装终极指南:告别DLL缺失烦恼

Visual C++ 运行时库一键安装终极指南:告别DLL缺失烦恼

Visual C 运行时库一键安装终极指南:告别DLL缺失烦恼 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾经遇到过这样的情况:下载了…

2026/7/6 0:05:19 阅读更多 →

周新闻

B站视频下载神器BiliTools:5分钟学会轻松保存任何B站内容

B站视频下载神器BiliTools:5分钟学会轻松保存任何B站内容

B站视频下载神器BiliTools:5分钟学会轻松保存任何B站内容 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/BiliTools …

2026/7/5 0:03:34 阅读更多 →
威胁模型全解析:从新手入门到实战应用,助你构建安全产品!

威胁模型全解析:从新手入门到实战应用,助你构建安全产品!

威胁模型的陌生现状在忙碌疲惫的一天里,参与了关于混合后量子密码学的讨论,应付端点攻击找茬的人,还参与留言板讨论后,发现“威胁模型”对多数人仍是陌生概念,且多被当作时髦用语。有趣的相关画作有一幅由 Embyr 创作的…

2026/7/5 0:03:34 阅读更多 →
渗透测试入门指南:从零基础到实战环境搭建

渗透测试入门指南:从零基础到实战环境搭建

1. 从“看热闹”到“入门”:我理解的渗透测试到底是什么?每次看到新闻里说某个大公司的数据被“黑”了,或者某个网站被攻击导致服务瘫痪,你是不是和我一样,心里会冒出两个念头:一是“这黑客真厉害”&#x…

2026/7/5 0:07:38 阅读更多 →

月新闻