tiktoken 是一个快速的 BPE 分词器,用于 OpenAI 的模型。
import tiktoken enc = tiktoken.get_encoding("o200k_base") assert enc.decode(enc.encode("hello world")) == "hello world" # 获取与 OpenAI API 中特定模型对应的分词器: enc = tiktoken.encoding_for_model("gpt-4o")
可以从 PyPI 安装 tiktoken 的开源版本:
pip install tiktoken
分词器 API 文档在 tiktoken/core.py 中。
使用 tiktoken 的示例代码可以在 OpenAI Cookbook 中找到。
tiktoken 比同类的开源分词器快 3-6 倍:
性能测试使用 1GB 文本和 GPT-2 分词器进行,使用了 tokenizers==0.13.2、transformers==4.24.0 和 tiktoken==0.2.0 中的 GPT2TokenizerFast。
请在 问题追踪器 中发布问题。
如果你在 OpenAI 工作,请确保查看内部文档或随时联系 @shantanu。
语言模型看到的文本不像你我看到的那样,它们 看到的是一系列数字(称为标记)。字节对编码(BPE)是将文本转换为标记的一种方法。它有几个理想的特性:
tiktoken 包含一个教育性的子模块,如果你想了解更多关于 BPE 的细节,它会更友好,包括帮助可视化 BPE 过程的代码:
from tiktoken._educational import * # 在少量文本上训练 BPE 分词器 enc = train_simple_encoding() # 可视化 GPT-4 编码器如何编码文本 enc = SimpleBytePairEncoding.from_tiktoken("cl100k_base") enc.encode("hello world aaaaaaaaaaaa")
你可能希望扩展 tiktoken 以支持新的编码。有两种方法可以做到这一点。
创建你想要的 Encoding 对象,然后简单地传递它。
cl100k_base = tiktoken.get_encoding("cl100k_base") # 在生产环境中,直接加载参数而不是访问私有属性 # 在 openai_public.py 中可以找到特定编码的参数示例 enc = tiktoken.Encoding( # 如果你要更改特殊标记集,请确保使用不同的名称 # 名称应该清楚地表明预期的行为。 name="cl100k_im", pat_str=cl100k_base._pat_str, mergeable_ranks=cl100k_base._mergeable_ranks, special_tokens={ **cl100k_base._special_tokens, "<|im_start|>": 100264, "<|im_end|>": 100265, } )
使用 tiktoken_ext 插件机制将你的 Encoding 对象注册到 tiktoken。
只有当你需要 tiktoken.get_encoding 找到你的编码时,这才有用,否则请选择方法 1。
要做到这一点,你需要在 tiktoken_ext 下创建一个命名空间包。
按照以下方式布局你的项目,确保省略 tiktoken_ext/__init__.py 文件:
my_tiktoken_extension
├── tiktoken_ext
│ └── my_encodings.py
└── setup.py
my_encodings.py 应该是一个包含名为 ENCODING_CONSTRUCTORS 变量的模块。这是一个字典,从编码名称映射到一个不接受参数并返回可以传递给 tiktoken.Encoding 的参数的函数,用于构造该编码。例子可以参见 tiktoken_ext/openai_public.py。详细信息请参见 tiktoken/registry.py。
你的 setup.py 应该类似这样:
from setuptools import setup, find_namespace_packages setup( name="my_tiktoken_extension", packages=find_namespace_packages(include=['tiktoken_ext*']), install_requires=["tiktoken"], ... )
然后只需 pip install ./my_tiktoken_extension,你就应该能够使用你的自定义编码了!确保不要使用可编辑安装 。


全球首个AI音乐社区
音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。


阿里Qoder团队推出的桌面端AI智能体
QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。


一站式搞定所有学习需求
不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。


为AI短剧协作而生
专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。


能听懂你表达的视频模型
Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。


国内直接访问,限时3折
输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动


职场AI,就用扣子
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!


多风格AI绘画神器
堆友平台由阿里巴巴设计团 队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

