Chinese word segmentation toolkit for spaCy (fork of pkuseg-python)
Project description
spacy-pkuseg: Chinese word segmentation toolkit for spaCy
This package is a fork of
pkuseg-python
that simplifies
installation and serialization for use with spaCy. The
underlying segmentation tools remain unmodified.
pkuseg:一个多领域中文分词工具包 (English Version)
pkuseg 是基于论文[Luo et. al, 2019]的工具包。其简单易用,支持细分领域分词,有效提升了分词准确度。
目录
主要亮点
pkuseg具有如下几个特点:
- 多领域分词。不同于以往的通用中文分词工具,此工具包同时致力于为不同领域的数据提供个性化的预训练模型。根据待分词文本的领域特点,用户可以自由地选择不同的模型。 我们目前支持了新闻领域,网络领域,医药领域,旅游领域,以及混合领域的分词预训练模型。在使用中,如果用户明确待分词的领域,可加载对应的模型进行分词。如果用户无法确定具体领域,推荐使用在混合领域上训练的通用模型。各领域分词样例可参考 example.txt。
- 更高的分词准确率。相比于其他的分词工具包,当使用相同的训练数据和测试数据,pkuseg可以取得更高的分词准确率。
- 支持用户自训练模型。支持用户使用全新的标注数据进行训练。
- 支持词性标注。
编译和安装
- 目前仅支持python3
- 为了获得好的效果和速度,强烈建议大家通过pip install更新到目前的最新版本
-
通过PyPI安装(自带模型文件):
pip3 install pkuseg 之后通过import pkuseg来引用
建议更新到最新版本以获得更好的开箱体验:
pip3 install -U pkuseg
-
如果PyPI官方源下载速度不理想,建议使用镜像源,比如:
初次安装:pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple pkuseg
更新:
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple -U pkuseg
-
如果不使用pip安装方式,选择从GitHub下载,可运行以下命令安装:
python setup.py build_ext -i
GitHub的代码并不包括预训练模型,因此需要用户自行下载或训练模型,预训练模型可详见release。使用时需设定"model_name"为模型文件。
注意:安装方式1和2目前仅支持linux(ubuntu)、mac、windows 64 位的python3版本。如果非以上系统,请使用安装方式3进行本地编译安装。
各类分词工具包的性能对比
我们选择jieba、THULAC等国内代表分词工具包与pkuseg做性能比较,详细设置可参考实验环境。
细领域训练及测试结果
以下是在不同数据集上的对比结果:
MSRA | Precision | Recall | F-score |
---|---|---|---|
jieba | 87.01 | 89.88 | 88.42 |
THULAC | 95.60 | 95.91 | 95.71 |
pkuseg | 96.94 | 96.81 | 96.88 |
Precision | Recall | F-score | |
---|---|---|---|
jieba | 87.79 | 87.54 | 87.66 |
THULAC | 93.40 | 92.40 | 92.87 |
pkuseg | 93.78 | 94.65 | 94.21 |
默认模型在不同领域的测试效果
考虑到很多用户在尝试分词工具的时候,大多数时候会使用工具包自带模型测试。为了直接对比“初始”性能,我们也比较了各个工具包的默认模型在不同领域的测试效果。请注意,这样的比较只是为了说明默认情况下的效果,并不一定是公平的。
Default | MSRA | CTB8 | PKU | All Average | |
---|---|---|---|---|---|
jieba | 81.45 | 79.58 | 81.83 | 83.56 | 81.61 |
THULAC | 85.55 | 87.84 | 92.29 | 86.65 | 88.08 |
pkuseg | 87.29 | 91.77 | 92.68 | 93.43 | 91.29 |
其中,All Average
显示的是在所有测试集上F-score的平均。
更多详细比较可参见和现有工具包的比较。
使用方式
代码示例
以下代码示例适用于python交互式环境。
代码示例1:使用默认配置进行分词(如果用户无法确定分词领域,推荐使用默认模型分词)
import pkuseg
seg = pkuseg.pkuseg() # 以默认配置加载模型
text = seg.cut('我爱北京天安门') # 进行分词
print(text)
代码示例2:细领域分词(如果用户明确分词领域,推荐使用细领域模型分词)
import pkuseg
seg = pkuseg.pkuseg(model_name='medicine') # 程序会自动下载所对应的细领域模型
text = seg.cut('我爱北京天安门') # 进行分词
print(text)
代码示例3:分词同时进行词性标注,各词性标签的详细含义可参考 tags.txt
import pkuseg
seg = pkuseg.pkuseg(postag=True) # 开启词性标注功能
text = seg.cut('我爱北京天安门') # 进行分词和词性标注
print(text)
代码示例4:对文件分词
import pkuseg
# 对input.txt的文件分词输出到output.txt中
# 开20个进程
pkuseg.test('input.txt', 'output.txt', nthread=20)
其他使用示例可参见详细代码示例。
参数说明
模型配置
pkuseg.pkuseg(model_name = "default", user_dict = "default", postag = False)
model_name 模型路径。
"default",默认参数,表示使用我们预训练好的混合领域模型(仅对pip下载的用户)。
"news", 使用新闻领域模型。
"web", 使用网络领域模型。
"medicine", 使用医药领域模型。
"tourism", 使用旅游领域模型。
model_path, 从用户指定路径加载模型。
user_dict 设置用户词典。
"default", 默认参数,使用我们提供的词典。
None, 不使用词典。
dict_path, 在使用默认词典的同时会额外使用用户自定义词典,可以填自己的用户词典的路径,词典格式为一行一个词(如果选择进行词性标注并且已知该词的词性,则在该行写下词和词性,中间用tab字符隔开)。
postag 是否进行词性分析。
False, 默认参数,只进行分词,不进行词性标注。
True, 会在分词的同时进行词性标注。
对文件进行分词
pkuseg.test(readFile, outputFile, model_name = "default", user_dict = "default", postag = False, nthread = 10)
readFile 输入文件路径。
outputFile 输出文件路径。
model_name 模型路径。同pkuseg.pkuseg
user_dict 设置用户词典。同pkuseg.pkuseg
postag 设置是否开启词性分析功能。同pkuseg.pkuseg
nthread 测试时开的进程数。
模型训练
pkuseg.train(trainFile, testFile, savedir, train_iter = 20, init_model = None)
trainFile 训练文件路径。
testFile 测试文件路径。
savedir 训练模型的保存路径。
train_iter 训练轮数。
init_model 初始化模型,默认为None表示使用默认初始化,用户可以填自己想要初始化的模型的路径如init_model='./models/'。
多进程分词
当将以上代码示例置于文件中运行时,如涉及多进程功能,请务必使用if __name__ == '__main__'
保护全局语句,详见多进程分词。
预训练模型
从pip安装的用户在使用细领域分词功能时,只需要设置model_name字段为对应的领域即可,会自动下载对应的细领域模型。
从github下载的用户则需要自己下载对应的预训练模型,并设置model_name字段为预训练模型路径。预训练模型可以在release部分下载。以下是对预训练模型的说明:
-
news: 在MSRA(新闻语料)上训练的模型。
-
web: 在微博(网络文本语料)上训练的模型。
-
medicine: 在医药领域上训练的模型。
-
tourism: 在旅游领域上训练的模型。
-
mixed: 混合数据集训练的通用模型。随pip包附带的是此模型。
欢迎更多用户可以分享自己训练好的细分领域模型。
版本历史
详见版本历史。
开源协议
- 本代码采用MIT许可证。
- 欢迎对该工具包提出任何宝贵意见和建议,请发邮件至jingjingxu@pku.edu.cn。
论文引用
该代码包主要基于以下科研论文,如使用了本工具,请引用以下论文:
- Ruixuan Luo, Jingjing Xu, Yi Zhang, Xuancheng Ren, Xu Sun. PKUSEG: A Toolkit for Multi-Domain Chinese Word Segmentation. Arxiv. 2019.
@article{pkuseg,
author = {Luo, Ruixuan and Xu, Jingjing and Zhang, Yi and Ren, Xuancheng and Sun, Xu},
journal = {CoRR},
title = {PKUSEG: A Toolkit for Multi-Domain Chinese Word Segmentation.},
url = {https://arxiv.org/abs/1906.11455},
volume = {abs/1906.11455},
year = 2019
}
其他相关论文
- Xu Sun, Houfeng Wang, Wenjie Li. Fast Online Training with Frequency-Adaptive Learning Rates for Chinese Word Segmentation and New Word Detection. ACL. 2012.
- Jingjing Xu and Xu Sun. Dependency-based gated recursive neural network for chinese word segmentation. ACL. 2016.
- Jingjing Xu and Xu Sun. Transfer learning for low-resource chinese word segmentation with a novel neural network. NLPCC. 2017.
常见问题及解答
- 为什么要发布pkuseg?
- pkuseg使用了哪些技术?
- 无法使用多进程分词和训练功能,提示RuntimeError和BrokenPipeError。
- 是如何跟其它工具包在细领域数据上进行比较的?
- 在黑盒测试集上进行比较的话,效果如何?
- 如果我不了解待分词语料的所属领域呢?
- 如何看待在一些特定样例上的分词结果?
- 关于运行速度问题?
- 关于多进程速度问题?
致谢
感谢俞士汶教授(北京大学计算语言所)与邱立坤博士提供的训练数据集!
作者
Ruixuan Luo (罗睿轩), Jingjing Xu(许晶晶), Xuancheng Ren(任宣丞), Yi Zhang(张艺), Bingzhen Wei(位冰镇), Xu Sun (孙栩)
北京大学 语言计算与机器学习研究组
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Hashes for spacy_pkuseg-0.0.30-cp310-cp310-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0550a1c1beb0f9987bb7d0e8fde364a959e1e978ea47e5109fd3dca1fa07a15a |
|
MD5 | 2f668e33f17b000590c8f25446c480b2 |
|
BLAKE2b-256 | cfb9aadc7eecf8211e6908fdad6fa5b3c8984cbe08368bcdc268498b6ce04a09 |
Hashes for spacy_pkuseg-0.0.30-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8c3a238dc042dc24db5593bf37bdbcb56e913ad950794b5eb7e0a4ac8efd51c2 |
|
MD5 | 0ed0b85ab9f5af797e75acb84b333c94 |
|
BLAKE2b-256 | 2d00d317d79c2081bdc8bdae59936fbd02472d49d752f488de91f9e1063c4bb7 |
Hashes for spacy_pkuseg-0.0.30-cp310-cp310-macosx_11_0_arm64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 58b73b79db36aba32d9a282def8e2b56280a5202cae131cd10de2b15d74e2a32 |
|
MD5 | a073c5f0ed83e2c96a8a5d1e59245c4f |
|
BLAKE2b-256 | 91d24dd12cdd7fd10bdba1c379eab92b083c859cc7783cef4bc73613491c0473 |
Hashes for spacy_pkuseg-0.0.30-cp310-cp310-macosx_10_9_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | fe0b5299b6880e746069d01b48081245e3f1764f84d4598fcc4f64975e18e053 |
|
MD5 | 633f874164abdb08f48f3f90c7da7334 |
|
BLAKE2b-256 | 080563df6316fc14fd19744945f8cf1012d9d108a75a98c55f85077eabcb3ecc |
Hashes for spacy_pkuseg-0.0.30-cp39-cp39-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 498ef9de95fdcf24cdd061a7a565fc99907db9f40f0514e3b267882c0dc752a7 |
|
MD5 | 3f6bde918f4c8854ac95281d2677bc03 |
|
BLAKE2b-256 | d33e210beea7534b6f8b2596f03d88f324765731b1286ff86d7031aff1312e3f |
Hashes for spacy_pkuseg-0.0.30-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0bfdcb2305a25fd416a2ba19986c5dea7449a2f7eda8726f0db162f9808b569f |
|
MD5 | 09db26db2495bff84dce1f3533af1f7e |
|
BLAKE2b-256 | 82b0f4db066be01ebe7ec0af7749679339a6ee3a48214ffe9ac89ef7c5397dd7 |
Hashes for spacy_pkuseg-0.0.30-cp39-cp39-macosx_11_0_arm64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | bfdb4253c2e79f5514d15523156adb2875e64339d8dd1e58cf7652b9804e4ba3 |
|
MD5 | 80f2d9275c1f8b4cbb063660f569abad |
|
BLAKE2b-256 | ac2bb3b23b97f4055568bc038dde73f1bd1066f07e0515ba01aa114c8bf5aaa0 |
Hashes for spacy_pkuseg-0.0.30-cp39-cp39-macosx_10_9_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 519f4ef4cfa0ec100332190784e827f0023a8c0c221ca4039e653befe8d94407 |
|
MD5 | eb8f3cd39a73881eadaf23fbf1cb3fbc |
|
BLAKE2b-256 | 2e12cb7baa0aac8e4e582cfbbb72e26b6578b97339598e5afd2f7b967a41393c |
Hashes for spacy_pkuseg-0.0.30-cp38-cp38-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 62d983b97e1c2d8527cfecc4175c57db27081265a116d8739a9801c12a3e483f |
|
MD5 | 08775995576a316857f4efeabd8d84a9 |
|
BLAKE2b-256 | 3f4a8451fd4f0739f7f5d3902d9ba0148d35e2d92849a1d034b054315643ea9a |
Hashes for spacy_pkuseg-0.0.30-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a8b4f47112fedd3d003f8dc197b7fa3c31e8ddf91734686e0175f1406b5f4184 |
|
MD5 | ca6ee36c0622cd61ac8166f117c17195 |
|
BLAKE2b-256 | 82ad92a095be0b3471a0ee2c69fad3a0d6a2004c00bf919d362c5d9075b3df1d |
Hashes for spacy_pkuseg-0.0.30-cp38-cp38-macosx_11_0_arm64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d1d237d9b4bb97d604552b3c16c4e74d9cb87618ee6b0e7751be4606d98bc0e9 |
|
MD5 | 2e2fb6d01df0f778c27c3285aa32cc31 |
|
BLAKE2b-256 | 219b6a7c8b50357d6462b5962887e1dc670ecfbccc949a25b49a780ff2a65651 |
Hashes for spacy_pkuseg-0.0.30-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6408342c4860254c9a28c1ca035e6c750cd640e037581f3465d0a409ddfc60f2 |
|
MD5 | 127919f48b1577fdae4f8ad9b771c800 |
|
BLAKE2b-256 | bbca1726cb726b958c97ecc7acc1d16ba172915cc1427248049bbf959abac535 |
Hashes for spacy_pkuseg-0.0.30-cp37-cp37m-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 17bb7d345478432b91b2dfebda4a57350ae56715047a69a6ce4a8d20283bd39d |
|
MD5 | 461eded72afda75d2645a8b3ecb3841c |
|
BLAKE2b-256 | 3477964d1bc161d37f72f2f2f1b12cfa1c9707078a7c0b2426a395f28b845107 |
Hashes for spacy_pkuseg-0.0.30-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e39147c770ef38d054b7e6a13f851fe11e999ed3f9fcbaa756cd253ed66420e8 |
|
MD5 | c857a8994f0cca6fa98c8e90f110ff38 |
|
BLAKE2b-256 | 3d861e90a52414c3404da70e3afcb68a5635ef8b2d0fbd6b87abdd6fea30cabf |
Hashes for spacy_pkuseg-0.0.30-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3b1455a62bc155e0a2d73e30b92b0e5bffc65cecab64f58f70924310d9baaa7f |
|
MD5 | c8bb06d50284b28c411300610f4f6acd |
|
BLAKE2b-256 | b1263d2b40c1a9d20519080c18d46b58cecf8edd401eb7eb9755ce00109c8b06 |
Hashes for spacy_pkuseg-0.0.30-cp36-cp36m-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 749e52e47a3d22465b8aafb1e59da504fc2cb73d9fec2a818c5cf63046e95f3d |
|
MD5 | 82f5523d698ccfd3b5690364723c9c87 |
|
BLAKE2b-256 | df461361ca7aa36720c67d1268ac741e3f6d3a25a5acb167af34e58944dcfbd3 |
Hashes for spacy_pkuseg-0.0.30-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d7fe5b9aa9436db57497dce02555707383f2ae57161033875d6170b274ba5c0d |
|
MD5 | 740a017fd79a915e02c017dea6beb5a3 |
|
BLAKE2b-256 | 62039b70d4f386976cda6df73202d2503fdb3144079e7ac3633488bfb0994092 |
Hashes for spacy_pkuseg-0.0.30-cp36-cp36m-macosx_10_9_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 677e78f7b4bb0666cb33314d835877ce0e271fe19fd87b4e500fa9b589d373b3 |
|
MD5 | 56f1abbb7dd3914ba38099b6851c3f0e |
|
BLAKE2b-256 | 72912b16ff975a1bcb2dd741af91c99ed2896166513ac0565333787afb409702 |