详情页标题前

腾讯云云点播Python SDK

详情页1

对于在服务端上传视频的场景,云点播提供 Python SDK 来实现。上传流程请参见 服务端上传指引

集成方式

使用 pip 安装

pip install vod-python-sdk

通过源码包安装

如果项目中没有使用 pip 工具,可以直接下载源码导入项目中使用:从 Github 访问单击下载 Python SDK下载最新代码,解压后:

$ cd vod-python-sdk$ python setup.py install

简单视频上传

初始化上传对象

使用云 API 密钥初始化 VodUploadClient 实例。

from qcloud_vod.vod_upload_client import VodUploadClient
client = VodUploadClient("your secretId", "your secretKey")

构造上传请求对象

from qcloud_vod.model import VodUploadRequest
request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"

调用上传

调用上传方法,传入接入点地域及上传请求。

try:    response = client.upload("ap-guangzhou", request)    print(response.FileId)    print(response.MediaUrl)except Exception as err:    # 处理业务异常    print(err)

说明:上传方法根据用户文件的长度,自动选择普通上传以及分片上传,用户不用关心分片上传的每个步骤,即可实现分片上传。

高级功能

携带封面

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("your secretId", "your secretKey")request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"request.CoverFilePath = "/data/file/Wildlife-Cover.png"try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl) print(response.CoverUrl)except Exception as err: # 处理业务异常 print(err)

指定任务流

首先 创建任务流模板 并为模板命名,发起任务流时,可以用任务流模板名设置Procedure参数,上传成功后会自动执行任务流。

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("your secretId", "your secretKey")request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"request.Procedure = "Your Procedure Name"try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl)except Exception as err: # 处理业务异常 print(err)

应用上传

传入 应用 ID,上传成功后资源只属于具体的应用。

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("your secretId", "your secretKey")request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"request.SubAppId = 101try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl)except Exception as err: # 处理业务异常 print(err)

指定存储地域

控制台 确认已经开通目标存储地域,若没有开通可以参考 上传存储设置,最后通过StorageRegion属性设置存储地域的 英文简称

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("your secretId", "your secretKey")request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"request.StorageRegion = "ap-chongqing"try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl)except Exception as err: # 处理业务异常 print(err)

指定分片并发数

分片并发数是针对大文件,拆分成多个分片同时进行上传。分片并发上传的优势在于可以快速完成单个文件的上传,SDK 会根据用户文件的长度,自动选择普通上传以及分片上传,用户不用关心分片上传的每个步骤,即可实现分片上传。而文件的分片并发数通过ConcurrentUploadNumber参数进行指定。

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("your secretId", "your secretKey")request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"request.ConcurrentUploadNumber = 5try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl)except Exception as err: # 处理业务异常 print(err)

使用临时证书上传

传入 临时证书 的相关密钥信息,使用临时证书验证身份并进行上传。

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("Credentials TmpSecretId", "Credentials TmpSecretKey", "Credentials Token")request = VodUploadRequest()request.MediaFilePath = "/data/file/Wildlife.mp4"try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl)except Exception as err: # 处理业务异常 print(err)

自适应码流文件上传

本 SDK 支持上传的自适应码流格式包括 HLS 和 DASH,同时要求 manifest(M3U8 或 MPD)所引用的媒体文件必须为相对路径(即不可以是 URL 和绝对路径),且位于 manifest 的同级目录或者下级目录(即不可以使用../)。在调用 SDK 上传接口时,MediaFilePath参数填写 manifest 路径,SDK 会解析出相关的媒体文件列表一并上传。

from qcloud_vod.vod_upload_client import VodUploadClientfrom qcloud_vod.model import VodUploadRequest
client = VodUploadClient("your secretId", "your secretKey")request = VodUploadRequest()request.MediaFilePath = "/data/file/prog_index.mp4"try: response = client.upload("ap-guangzhou", request) print(response.FileId) print(response.MediaUrl)except Exception as err: # 处理业务异常 print(err)

接口描述

上传客户端类VodUploadClient

属性名称 属性描述 类型 必填
secretId 云 API 密钥 ID。 String
secretKey 云 API 密钥 Key。 String

上传请求类VodUploadRequest

属性名称 属性描述 类型 必填
MediaFilePath 待上传的媒体文件路径。必须为本地路径,不支持 URL。 String
SubAppId 云点播 应用 ID。如果要访问应用中的资源,则将该字段填写为应用 ID,否则无需填写该字段。 Integer
MediaType 待上传的媒体文件类型,可选类型请参见 视频上传综述,若 MediaFilePath 路径带后缀可不填。 String
MediaName 上传后的媒体名称,若不填默认采用 MediaFilePath 的文件名。 String
CoverFilePath 待上传的封面文件路径。必须为本地路径,不支持 URL。 String
CoverType 待上传的封面文件类型,可选类型请参见 视频上传综述,若 CoverFilePath 路径带后缀可不填。 String
Procedure 上传后需要自动执行的任务流名称,该参数在创建任务流(API 方式控制台方式)时由用户指定。具体请参考 任务流综述 String
ExpireTime 媒体文件过期时间,格式按照 ISO 8601 标准表示,详见 ISO 日期格式说明 String
ClassId 分类 ID,用于对媒体进行分类管理,可通过 创建分类 接口,创建分类,获得分类 ID。 Integer
SourceContext 来源上下文,用于透传用户请求信息,上传回调接口将返回该字段值,最长250个字符。 String
StorageRegion 存储地域,指定预期希望存储的地域,该字段填写为存储地域的 英文简称 String
ConcurrentUploadNumber 分片并发数,针对大文件分片时有效。 Integer

上传响应类VodUploadResponse

属性名称 属性描述 类型
FileId 媒体文件的唯一标识。 String
MediaUrl 媒体播放地址 String
CoverUrl 媒体封面地址 String
RequestId 唯一请求 ID,每次请求都会返回。定位问题时需要提供该次请求的 RequestId。 String

上传方法VodUploadClient.upload(String region, VodUploadRequest request)

参数名称 参数描述 类型 必填
region 接入点地域,即请求到哪个地域的云点播服务器,不同于存储地域,具体参考支持的 地域列表 String
request 上传请求 VodUploadRequest

错误码表

状态码 含义
InternalError 内部错误。
InvalidParameter.ExpireTime 参数值错误:过期时间。
InvalidParameterValue.CoverType 参数值错误:封面类型。
InvalidParameterValue.MediaType 参数值错误:媒体类型。
InvalidParameterValue.SubAppId 参数值错误:应用 ID。
InvalidParameterValue.VodSessionKey 参数值错误:点播会话。
ResourceNotFound 资源不存在。



云点播官网1折活动,限时活动,即将结束,速速收藏
同尘科技腾讯云授权服务中心。
购买腾讯云产品享受折上折,更有现金返利。同意关联立享优惠

转转请注明出处:https://www.yunxiaoer.com/143408.html

(0)
上一篇 2023年12月9日
下一篇 2023年12月9日
详情页2

相关推荐

  • 腾讯云云点播社交短视频

    场景描述 社交短视频,顾名思义社交为主体,通过短视频的方式促进社交。该场景具有如下核心需求: 核心诉求 说明 视频快速制作并分享 用户通过短视频的形式记录并分享生活,参与了视频生成、处理、上传、分发和播放等多个环节。让用户简单快速实现这一系列操作将提高用户的参与热情,有利于社交短视频平台的发展,是其核心诉求之一。 媒体智能 在社交短视频平台,用户也可以关注有…

    腾讯云 2023年12月9日
  • 腾讯云容器服务为数据盘设置文件系统卷标同尘科技

    本文向您介绍如何为数据盘设置文件系统卷标。 使用背景 NVMe 数据盘的盘符由 NVMe 盘的驱动生成,如果驱动加载顺序不一致可能会导致盘符变化。因此,由于操作系统和物理机的限制,云服务器 CVM 部分普通机型(如黑石、高 IO 型、高性能 HCC 等)挂载多块 NVMe 数据盘时,重启系统后盘符可能会错乱。更多内容可参考 Linux 云服务器重启后云硬盘未…

    2023年12月9日
  • 腾讯云TDSQL-C MySQL版库表恢复:按时间点

    通过一个完整的数据备份以及后续一段时间的 binlog 备份,就可以将特定库表恢复到任意时间点。在知晓误操作发生的时间点后,可以通过此方式,将误操作的数据库或表恢复到误操作发生之前。 前提条件 备份列表由数据备份文件和日志备份文件产生,自动备份设置请参见 自动备份。集群状态处于运行中。 注意事项 库表回档需明确指定所需回档的库表,若无法确定所有涉及的库表,建…

    2023年12月9日
  • 阿里云RDS数据库DeleteDatabase – 删除数据库-云淘科技

    该接口用于删除RDS实例下的指定数据库。 接口说明 适用引擎 RDS MySQL RDS PostgreSQL RDS SQL Server RDS MariaDB 相关功能文档 注意 使用该接口前,请仔细阅读功能文档,确保完全了解使用接口的前提条件及使用后造成的影响后,再进行操作。 RDS MySQL删除数据库 RDS PostgreSQL删除数据库 RD…

    阿里云数据库 2023年12月9日
  • 信息流广告,信息流部分建议宽度830px,只针对默认列表样式,顺序随机
  • 阿里云RDS数据库使用pg_restore恢复逻辑备份文件数据-云淘科技

    本文介绍如何使用pg_restore命令将逻辑备份文件(.dump文件)中的数据恢复到RDS PostgreSQL实例或本地PostgreSQL数据库中。 说明 对于少量的数据,您可参考本文使用逻辑备份进行快速恢复,例如恢复某个表的数据。对于大量的数据,建议您使用全量物理备份来恢复数据到新的实例中,然后通过数据传输服务DTS将数据迁移回原有实例。 更多数据恢…

    2023年12月10日

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信
本站为广大会员提供阿里云、腾讯云、华为云、百度云等一线大厂的购买,续费优惠,保证底价,买贵退差。