×

TikTokitem_search_video关键词视频列表接口对接全攻略:从入门到精通

万邦科技Lex 万邦科技Lex 发表于2025-12-28 13:35:31 浏览60 评论0

抢沙发发表评论

                                                   注册账号免费测试TikTokAPI数据接口

TikTok 的item_search_video接口是按关键词批量检索平台视频列表的核心工具,支持按地区、发布时间、互动量、内容类型、带货属性等多维度筛选,返回视频基础信息、互动数据、创作者信息、商品标签等关键内容,适配跨境内容聚合、爆款视频挖掘、带货效果分析、社媒舆情监测等场景。本攻略从接口认知、权限获取、实操对接、调试排错到生产级优化,提供全流程结构化指导,兼顾入门易用性与企业级稳定性,助力开发者高效完成跨境对接。


一、接口核心认知:功能与适配场景

1. 接口定位与核心价值

  • 核心功能:输入搜索关键词(支持多关键词组合、语言适配),筛选 TikTok 全球公开视频(短视频、直播回放、创作者合集),支持地区 / 语言过滤、时间范围筛选、排序规则自定义,返回分页视频列表;可联动item_get_video接口获取单视频精细化详情。

  • TikTok 平台特性

    • 全球数据覆盖:收录 150 + 国家 / 地区的公开视频,涵盖娱乐、美妆、3C、跨境电商等 40 + 内容类目,新视频收录延迟 3-5 分钟;

    • 跨境专属筛选:支持按地区(如 US/UK/IN)、语言(如英语 / 西班牙语)、带货属性(是否挂小黄车)、内容类型(原创 / 转载 / 合拍) 筛选,适配跨境业务需求;

    • 互动数据前置:搜索结果直接返回播放量、点赞数、完播率等核心互动指标,无需二次调用;

    • 多关键词逻辑:支持空格分隔(AND 逻辑)、竖线|分隔(OR 逻辑),适配复杂检索场景。

  • 典型应用场景

    1. 跨境内容聚合:搭建垂直品类内容平台(如 “跨境美妆爆款”“3C 测评” 专区),按关键词聚合 TikTok 相关视频;

    2. 爆款挖掘:按播放量 / 完播率排序,筛选特定地区近期爆款视频,辅助跨境账号选题;

    3. 带货效果分析:筛选带商品标签的视频,统计关键词下商品曝光量、互动转化数据;

    4. 社媒舆情监测:追踪品牌 / 事件关键词相关视频,实时监控传播量与评论倾向,适配跨境品牌合规运营。

2. 核心参数与返回字段

(1)请求参数(必填 + 可选,按优先级排序)

参数名称类型是否必填说明应用示例
client_id/keystring接口调用标识(官方为 client_id,第三方为 key)tiktok_abc123
client_secret/secretstring签名密钥(官方用于 token 生成,第三方用于签名校验)tiktok_def456
keywordstring搜索关键词(支持多语言,需 URL 编码)`smartphone review手机测评 `
regionstring目标地区(ISO 3166-1 alpha-2,默认 global)USUKIN
languagestring视频语言(ISO 639-1,默认 auto)eneszh
time_rangestring发布时间范围,默认all1day7days30dayscustom
start_datestring自定义开始日期(time_range=custom 时必填)2025-01-01
end_datestring自定义结束日期(time_range=custom 时必填)2025-12-31
sort_typestring排序方式,默认relevanceplay(播放量倒序)、like(点赞数倒序)、pubtime(发布时间倒序)、completion(完播率倒序)
has_productint是否仅返回带货视频,默认 0(不限)1(仅带货视频)
content_typestring内容类型,默认alloriginal(原创)、duet(合拍)、stitch(缝合)
duration_rangestring视频时长范围,默认all0-60(1 分钟内)、60-300(1-5 分钟)、300+(5 分钟以上)
page_noint页码,默认 1,最大支持 100 页1、5、10
page_sizeint每页视频数,默认 20,最大支持 5020、30、50
access_tokenstring官方必填OAuth2.0 授权令牌(有效期 2 小时)eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
timestamplong第三方必填请求时间戳(毫秒级,有效期 5 分钟)1735689600000
signstring第三方必填签名值(MD5 32 位大写,核心校验项)32 位 MD5 大写串
注意事项
  1. 地区参数region需用 ISO 3166-1 alpha-2 标准码,如美国US、印度IN、英国UK

  2. 时间范围custom模式下,start_dateend_date需同时传入,格式为YYYY-MM-DD,跨度不超过 1 年;

  3. 排序方式play对应近 30 天播放量,适配爆款视频筛选;completion需企业权限。

(2)返回核心字段(按业务场景分类)

字段分类核心字段说明
视频基础信息video_id视频唯一 ID(TikTok 原生标识)

title视频标题(多语言,含话题标签)

cover_url高清封面图 URL

duration视频时长(秒)

create_time发布时间(时间戳 / 格式化字符串)

region视频所属地区

language视频语言

content_type内容类型(原创 / 合拍 / 缝合)

status视频状态(0 = 正常,1 = 审核中,2 = 已下架)
互动数据play_count近 30 天播放量

like_count点赞数

comment_count评论数

share_count转发数

favorite_count收藏数

completion_rate播放完成率(%,需企业权限)
创作者信息author_id创作者 ID

author_name创作者昵称

author_avatar创作者头像 URL

author_follower创作者粉丝数(需权限)

author_verified认证状态(0 = 未认证,1 = 个人认证,2 = 企业认证)
带货与内容信息products商品标签列表(含商品 ID、名称、价格、链接)

hashtags话题标签列表(如 #fyp、#tiktokmademebuyit)

music_idBGM 音乐 ID

music_titleBGM 名称
分页信息total关键词匹配视频总数

page_no当前页码

page_total总页码

has_more是否有更多数据(true/false)

3. 接口限制与注意事项

  • 调用频率限制

    接入方式调用频率适用场景
    TikTok 官方个人10 次 / 分钟个人调研、小型工具
    TikTok 官方企业60 次 / 分钟商业内容聚合、舆情监测
    第三方合规服务商30-100 次 / 分钟跨境电商数据分析、批量内容采集
  • 数据缓存规则:搜索结果缓存 30 分钟,热门关键词(如 #fyp)缓存缩短至 10 分钟;企业用户可申请refresh=1强制刷新(需额外权限);

  • 内容限制:已下架 / 违规视频、隐私视频(仅好友可见)、未过审视频不会返回;版权内容(如音乐 MV)仅返回基础信息,无播放链接;

  • 合规要求:禁止批量抓取视频源文件用于商用,播放链接需跳转 TikTok 站内,二次创作需遵守 TikTok 版权规则与 GDPR 等数据保护法规。


二、对接前准备:权限与环境搭建

1. 获取接口权限(两条合规路径)

TikTok item_search_video 接口无公开免费接入渠道,需通过官方开放平台合规第三方服务商获取权限,具体对比如下:
接入方式操作步骤优缺点
TikTok 官方开放平台1. 登录 TikTok for Developers;2. 完成企业认证(需营业执照、法人信息、跨境业务证明);3. 创建应用,选择 “Content Search API” 类目;4. 提交item_search_video接口申请,附业务用途说明;5. 通过 OAuth2.0 流程获取access_token优点:数据权威、字段完整、合规性强;缺点:审核严格(周期 7-15 个工作日)、需企业资质、部分字段(完播率)需专项授权
第三方合规服务商1. 选择口碑服务商(如 APISpace、聚合数据);2. 注册账号并完成实名认证;3. 购买 TikTok 视频搜索接口套餐;4. 在服务商后台获取keysecret和接口调用地址优点:接入快(10 分钟完成)、无需复杂资质、调试工具完善;缺点:部分进阶字段(商品标签)需付费升级、调用次数有配额限制
风险提示:严禁使用非法爬虫接口,违反 TikTok 用户协议及《计算机信息网络国际联网安全保护管理办法》,存在账号封禁、法律追责风险。

2. 技术环境准备

(1)支持语言与协议

  • 协议:HTTPS(强制,保障跨境数据传输安全);

  • 开发语言:支持 Python、Java、PHP、Go 等所有主流语言,推荐Python(适配跨境数据处理、多语言解析与异步并发)。

(2)必备工具与依赖

工具类型推荐工具用途
调试工具Postman快速验证接口可用性,排除代码逻辑干扰

在线 MD5 工具校验签名生成正确性

TikTok 地区 / 语言编码查询工具获取region/language参数的正确取值
开发依赖requests(Python)发送 HTTP 请求

hashlib(Python)生成接口签名

pandas(Python)批量整理视频列表数据

jsonpath-ng快速解析嵌套 JSON 响应

python-jose处理 OAuth2.0 授权(官方接口)
辅助工具Redis缓存搜索结果,减少重复请求

logging记录接口调用日志,便于问题追溯

三、实操步骤:接口对接全流程(Python 示例)

步骤 1:理解认证与签名规则

(1)官方接口 OAuth2.0 授权流程

  1. 构建授权 URL,引导用户授权;

  2. 获取授权码,通过client_idclient_secret、授权码获取access_tokenrefresh_token

  3. 调用接口时,在 Header 中携带Authorization: Bearer {access_token}

  4. access_token有效期 2 小时,通过refresh_token每 1.5 小时刷新一次。

(2)第三方接口签名规则(MD5 加密)

  1. 剔除参数中的sign字段;

  2. 将剩余参数按参数名 ASCII 升序排序;

  3. 拼接成key1=value1&key2=value2&...的字符串;

  4. 末尾拼接&secret=你的secret

  5. 对字符串进行 MD5 加密,生成 32 位大写字符串作为sign

步骤 2:完整代码实现(第三方签名 + 官方 OAuth2.0 双示例)

(1)依赖安装

bash
运行
pip install requests pandas jsonpath-ng python-jose

(2)第三方签名方式代码(快速接入)

import requests
import hashlib
import time
import json
import pandas as pd
import logging
from urllib.parse import urlencode

# 日志配置
logging.basicConfig(
    level=logging.INFO,
    format="%(asctime)s - %(levelname)s - %(message)s",
    handlers=[logging.FileHandler("tiktok_item_search_video.log"), logging.StreamHandler()]
)

# 接口配置(替换为自身信息)
CONFIG = {
    "key": "你的第三方key",
    "secret": "你的第三方secret",
    "api_url": "https://api.example.com/tiktok/item_search_video",
    "save_path": "TikTok视频搜索列表.xlsx"
}

def generate_sign(params: dict, secret: str) -> str:
    """生成第三方接口签名(MD5 32位大写)"""
    params.pop("sign", None)
    sorted_params = sorted(params.items(), key=lambda x: x[0])
    param_str = urlencode(sorted_params, encoding="utf-8") + f"&secret={secret}"
    md5 = hashlib.md5()
    md5.update(param_str.encode("utf-8"))
    return md5.hexdigest().upper()

def standardize_video_data(raw_video: dict) -> dict:
    """标准化视频数据,统一输出格式"""
    create_time = raw_video.get("create_time", 0)
    create_time_str = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(create_time)) if create_time else ""
    duration = raw_video.get("duration", 0)
    duration_str = f"{duration//60}:{duration%60:02d}"

    return {
        "搜索关键词": raw_video.get("keyword", ""),
        "视频ID": raw_video.get("video_id", ""),
        "标题": raw_video.get("title", ""),
        "封面链接": raw_video.get("cover_url", ""),
        "时长": duration_str,
        "发布时间": create_time_str,
        "地区": raw_video.get("region", ""),
        "语言": raw_video.get("language", ""),
        "播放量": raw_video.get("play_count", 0),
        "点赞数": raw_video.get("like_count", 0),
        "评论数": raw_video.get("comment_count", 0),
        "分享数": raw_video.get("share_count", 0),
        "收藏数": raw_video.get("favorite_count", 0),
        "创作者ID": raw_video.get("author_id", ""),
        "创作者昵称": raw_video.get("author_name", ""),
        "认证状态": "认证" if raw_video.get("author_verified", 0) else "未认证",
        "话题标签": ",".join(raw_video.get("hashtags", [])),
        "商品数量": len(raw_video.get("products", [])) if raw_video.get("products") else 0,
        "视频状态": "正常" if raw_video.get("status", 0) == 0 else "已下架/违规",
        "请求时间": time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
    }

def tiktok_item_search_video(
    keyword: str,
    region: str = "global",
    time_range: str = "all",
    sort_type: str = "relevance",
    has_product: int = 0,
    page_no: int = 1,
    page_size: int = 20
) -> dict:
    """调用TikTok item_search_video接口(第三方签名方式)"""
    # 校验参数
    if time_range == "custom" and not (start_date and end_date):
        logging.error("time_range=custom时,start_date和end_date为必填参数")
        return {"success": False, "error_msg": "缺少自定义时间参数"}

    # 构建基础参数
    params = {
        "key": CONFIG["key"],
        "keyword": keyword,
        "region": region,
        "time_range": time_range,
        "sort_type": sort_type,
        "has_product": has_product,
        "page_no": page_no,
        "page_size": page_size,
        "timestamp": int(time.time() * 1000)
    }

    # 补充自定义时间参数
    if time_range == "custom":
        params["start_date"] = start_date
        params["end_date"] = end_date

    # 生成签名
    params["sign"] = generate_sign(params, CONFIG["secret"])

    try:
        response = requests.post(
            url=CONFIG["api_url"],
            data=json.dumps(params),
            headers={"Content-Type": "application/json"},
            timeout=20,
            verify=True
        )
        response.raise_for_status()
        result = response.json()

        if result.get("code") == 0 or result.get("status") == "success":
            raw_data = result.get("data", {})
            video_list = raw_data.get("item_list", [])
            total = raw_data.get("total", 0)
            page_total = raw_data.get("page_total", 1)

            # 标准化数据
            standard_videos = []
            for video in video_list:
                video["keyword"] = keyword
                standard_videos.append(standardize_video_data(video))

            return {
                "success": True,
                "data": standard_videos,
                "total": total,
                "page_total": page_total,
                "error_msg": ""
            }
        else:
            error_msg = result.get("msg", result.get("message", "接口调用失败"))
            logging.error(f"接口返回错误(关键词:{keyword}):{error_msg}(code={result.get('code')})")
            return {"success": False, "error_msg": error_msg}
    except requests.exceptions.RequestException as e:
        logging.error(f"网络请求异常(关键词:{keyword}):{str(e)}")
        return {"success": False, "error_msg": f"网络异常:{str(e)}"}
    except Exception as e:
        logging.error(f"数据解析异常(关键词:{keyword}):{str(e)}")
        return {"success": False, "error_msg": f"解析异常:{str(e)}"}

# 调用示例
if __name__ == "__main__":
    # 单页获取示例:搜索“smartphone review”,美国地区,近30天,按播放量排序
    single_page_result = tiktok_item_search_video(
        keyword="smartphone review",
        region="US",
        time_range="30days",
        sort_type="play",
        page_size=20
    )
    if single_page_result["success"]:
        print(f"获取到 {len(single_page_result['data'])} 条视频数据")
        for video in single_page_result["data"][:5]:
            print(f"标题:{video['标题']} | 播放量:{video['播放量']} | 创作者:{video['创作者昵称']}")
    else:
        print(f"单页获取失败:{single_page_result['error_msg']}")

(3)官方接口 OAuth2.0 调用示例(核心片段)

from jose import jwt
import requests

def get_access_token(client_id, client_secret, code, redirect_uri):
    """通过授权码获取access_token"""
    url = "https://open-api.tiktok.com/oauth/access_token/"
    data = {
        "client_id": client_id,
        "client_secret": client_secret,
        "code": code,
        "grant_type": "authorization_code",
        "redirect_uri": redirect_uri
    }
    response = requests.post(url, data=data)
    return response.json().get("access_token")

def tiktok_official_item_search(access_token, keyword, region, sort_type):
    """调用TikTok官方视频搜索接口"""
    url = "https://open-api.tiktok.com/video/search/"
    headers = {"Authorization": f"Bearer {access_token}"}
    params = {
        "keyword": keyword,
        "region": region,
        "sort_type": sort_type,
        "page_size": 20,
        "fields": "id,title,cover_image_url,duration,stats,author,products"
    }
    response = requests.get(url, headers=headers, params=params)
    return response.json()

四、调试与问题排查:快速解决对接异常

1. 优先用 Postman 调试(排除代码干扰)

  1. 构造请求:新建 POST/GET 请求,填写接口 URL,请求头设置Content-Type: application/json

  2. 填写参数:在请求体 / 参数中输入client_id/keykeywordtimestamp等必填项,按需补充region/time_range等参数;

  3. 生成签名 / 携带 token:官方接口在 Header 中携带Authorization: Bearer {access_token},第三方接口计算sign并填入;

  4. 发送请求:查看响应结果,验证接口可用性。

2. 高频问题排查表

问题现象常见原因解决方案
认证失败(401)1. client_id/keyclient_secret/secret错误;
2. access_token过期 / 无效;
3. 签名生成错误;
4. 时间戳过期
1. 核对密钥与后台一致;
2. 重新获取access_token
3. 按 ASCII 升序排序参数并重新计算签名;
4. 校准本地时间(误差≤5 分钟)
权限不足(403)1. 未申请item_search_video接口权限;
2. 无带货 / 完播率数据权限;
3. 调用频率超限
1. 在开放平台 / 服务商后台确认接口已开通;
2. 申请对应进阶权限;
3. 增加请求间隔,降低调用频率
参数错误(400)1. region/language格式错误;
2. time_range=custom未传日期;
3. sort_type取值非法
1. 查阅 ISO 3166-1/639-1 标准码;
2. 补充start_dateend_date
3. 核对sort_type取值(参考参数表)
无数据返回1. 关键词过于精准 / 无匹配视频;
2. 筛选条件过于严格;
3. 视频未被接口收录
1. 放宽关键词(如 “smartphone review 2025” 改为 “smartphone review”);
2. 移除地区 / 时间等筛选条件;
3. 在 TikTok 官网搜索关键词,确认是否有相关视频
字段缺失(如无商品列表)1. 账号无企业权限;
2. 视频未关联商品;
3. 接口版本不支持
1. 升级为企业账号或申请专项权限;
2. 确认视频是否带商品标签;
3. 联系服务商升级接口版本

五、进阶优化:生产级稳定性提升

1. 性能优化

  • 异步并发请求:多关键词 / 多页码批量获取时,使用aiohttp实现异步请求,控制并发数≤5(避免频率超限),效率比同步提升 4-6 倍;

  • 智能缓存策略:用 Redis 缓存关键词+地区+时间范围组合的搜索结果,缓存 key=tiktok_search_关键词_地区_时间范围,有效期 30 分钟;对无结果的关键词,缓存空结果(有效期 10 分钟),避免无效请求;

  • 分页智能停止:获取第 1 页后,根据page_total计算总页码,仅请求有效页码,避免page_no超过总页码的无效请求。

2. 数据质量优化

  • 数据去重:按video_id去重,避免同一视频多次入库;

  • 异常值过滤:过滤播放量为 0、状态为下架的无效数据;

  • 关键词扩展:结合多语言分词工具对核心关键词进行扩展(如 “smartphone review” 扩展为 “phone review”“mobile review”),提升搜索覆盖率。

3. 合规与安全

  • 密钥管理:生产环境将client_id/keyclient_secret/secret存储在环境变量 / 配置中心(如 Nacos),禁止硬编码,定期轮换密钥(每 3 个月一次);

  • 数据合规:视频数据仅用于合规业务,播放链接需跳转 TikTok 站内,二次创作需获得创作者授权,遵守 GDPR、CCPA 等跨境数据保护法规;

  • 日志审计:详细记录每次接口调用的参数、响应、错误信息,保留至少 7 天日志,便于合规审计与问题追溯。


六、扩展场景:接口联动与功能升级

  1. 联动item_get_video接口:通过item_search_video获取video_id列表后,批量调用item_get_video获取视频分 P、字幕、播放链接等精细化详情;

  2. 跨境爆款分析模型:结合播放量完播率商品转化率等指标,构建爆款评分公式,自动筛选优质带货视频;

  3. 实时关键词监测:使用APScheduler定时调用接口,监控目标关键词的视频新增量、播放量变化,触发舆情 / 爆款告警


群贤毕至

访客