news 2026/6/9 16:55:11

如何通过Python SDK更新Collection中已存在的Doc

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何通过Python SDK更新Collection中已存在的Doc

说明

若更新Doc时指定id不存在,则本次更新Doc操作无效

如只更新部分属性fields,其他未更新属性fields默认被置为None

Python SDK 1.0.11版本后,更新Doc时vector变为非必填项

前提条件

已创建Cluster

已获得API-KEY

已安装最新版SDK

接口定义

Python示例:

Collection.update(

docs: Union[Doc, List[Doc], Tuple, List[Tuple]],

partition: Optional[str] = None,

async_req: False

) -> DashVectorResponse

使用示例

说明

需要使用您的api-key替换示例中的YOUR_API_KEY、您的Cluster Endpoint替换示例中的YOUR_CLUSTER_ENDPOINT,代码才能正常运行。

本示例需要参考新建Collection-使用示例提前创建好名称为quickstart的Collection。

Python示例:

import dashvector

from dashvector import Doc

import numpy as np

client = dashvector.Client(

api_key='YOUR_API_KEY',

endpoint='YOUR_CLUSTER_ENDPOINT'

)

collection = client.get(name='quickstart')

更新Doc

Python示例:

# 通过Doc对象update

ret = collection.update(

Doc(

id='1',

vector=[0.1, 0.2, 0.3, 0.4]

)

)

# 判断update是否成功

assert ret

# 简化形式:通过Tuple update

ret = collection.update(

('2', [0.1, 0.1, 0.1, 0.1]) # (id, vector)

)

更新带有Fields的Doc

Python示例:

# update单条数据,并设置Fields Value

ret = collection.update(

Doc(

id='3',

vector=np.random.rand(4),

fields={

# 设置创建Collection时预定义的Fields Value

'name': 'zhangsan', 'weight':70.0, 'age':30,

# 设置Schema-Free的Field & Value

'anykey1': 'str-value', 'anykey2': 1,

'anykey3': True, 'anykey4': 3.1415926

}

)

)

# update单条数据,并设置Fields Value

ret = collection.update(

('4', np.random.rand(4), {'foo': 'bar'}) # (id, vector, fields)

)

批量更新Doc

Python示例:

# 通过Doc对象,批量update 10条数据

ret = collection.update(

[

Doc(id=str(i+5), vector=np.random.rand(4)) for i in range(10)

]

)

# 简化形式:通过Tuple,批量update 3条数据

ret = collection.update(

[

('15', [0.2,0.7,0.8,1.3], {'age': 20}),

('16', [0.3,0.6,0.9,1.2], {'age': 30}),

('17', [0.4,0.5,1.0,1.1], {'age': 40})

] # List[(id, vector, fields)]

)

# 判断批量update是否成功

assert ret

异步更新Doc

Python示例:

# 异步批量update 10条数据

ret_funture = collection.update(

[

Doc(id=str(i+18), vector=np.random.rand(4), fields={'name': 'foo' + str(i)}) for i in range(10)

],

async_req=True

)

# 等待并获取异步update结果

ret = ret_funture.get()

更新带有Sparse Vector的Doc

Python示例:

ret = collection.update(

Doc(

id='28',

vector=[0.1, 0.2, 0.3, 0.4],

sparse_vector={1:0.4, 10000:0.6, 222222:0.8}

)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 0:07:02

7、商业技术管理的现状、趋势与挑战

商业技术管理的现状、趋势与挑战 重新审视与宏观趋势 曾经,我们在商业技术应用上存在诸多问题,如零散的应用、考虑不周的采购和人员配置策略、疯狂的组织策略以及错误的衡量指标。如今,是时候重新审视了,摆脱过去的混乱,关注身边的协作与集成可能性。上世纪90年代中后期的…

作者头像 李华
网站建设 2026/6/10 13:02:25

万亿参数MoE架构落地:Kimi K2如何重新定义企业智能助手效率边界

导语 【免费下载链接】Kimi-K2-Base Kimi K2 是一款前沿的专家混合(MoE)语言模型,激活参数达320亿,总参数量达1万亿。采用 Muon 优化器训练,Kimi K2 在知识前沿、推理和编程任务中表现卓越,同时针对智能体能…

作者头像 李华
网站建设 2026/6/9 19:24:34

AI编程助手:Aider使用手册(中文版)

一、安装指南使用 aider-install快速开始如果您已安装 Python 3.8 - 3.13,可以通过以下方式快速开始:首先,安装 Aider:python -m pip install aider-installaider-install开始在您的代码库中使用 Aider:# 进入您的代码…

作者头像 李华
网站建设 2026/6/10 15:45:15

OpenLayers时序地图实战指南:从静态到动态的数据可视化革命

OpenLayers时序地图实战指南:从静态到动态的数据可视化革命 【免费下载链接】openlayers OpenLayers 项目地址: https://gitcode.com/gh_mirrors/op/openlayers 你是否遇到过这样的困境:面对海量的时空数据,却无法直观展示其随时间变化…

作者头像 李华
网站建设 2026/6/10 12:53:43

基于vue的酒店宾馆客房管理系统_6u85gvj9_springboot php python nodejs

目录具体实现截图项目介绍论文大纲核心代码部分展示项目运行指导结论源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作具体实现截图 本系统(程序源码数据库调试部署讲解)同时还支持java、ThinkPHP、Node.js、Spring B…

作者头像 李华
网站建设 2026/6/10 15:05:08

PocketHub技术架构解析:构建移动优先的GitHub协作平台

技术架构概述 【免费下载链接】PocketHub PocketHub Android App 项目地址: https://gitcode.com/gh_mirrors/po/PocketHub PocketHub作为GitHub官方Android应用的社区继承者,采用模块化架构设计,实现了完整的GitHub API移动端封装。该应用基于现…

作者头像 李华