Awesome
NodeJieba "结巴"分词的 Node.js 版本 English
介绍
nodejieba
是"结巴"中文分词的 Node.js 版本实现,由 CppJieba 提供底层分词算法实现,是兼具高性能和易用性两者的 Node.js 中文分词组件。
特点
- 词典载入方式灵活,无需配置词典路径也可使用,需要定制自己的词典路径时也可灵活定制。
- 底层算法实现是 C++,性能高效。
- 支持多种分词算法,各种分词算法见 CppJieba 的 README.md 介绍。
- 支持动态补充词库。
对实现细节感兴趣的请看如下博文:
下载
npm install nodejieba
由于默认源速度很慢并且 GitHub 访问不稳定,可以使用国内镜像,命令如下:
npm install nodejieba --registry=https://registry.npmmirror.com --nodejieba_binary_host_mirror=https://registry.npmmirror.com/-/binary/nodejieba/
用法
import { cut } from "nodejieba";
const result = cut("南京市长江大桥");
console.log(result);
//["南京市","长江大桥"]
更详细的其他用法请看 测试案例
配置词典载入
如果没有主动调用词典函数时,则会在第一次调用 cut
等功能函数时,自动载入默认词典。
如果要主动触发词典载入,则使用以下函数主动触发。
import { load } from "nodejieba";
load();
以上用法会自动载入所有默认词典。
如果需要载入自己的词典,而不是默认词典,你需要传递参数。
比如载入自己的用户词典:
import { load } from "nodejieba";
load({
userDict: "./test/testdata/userdict.utf8",
});
字典载入函数 load 的参数项都是可选的,如果没有对应的项则自动填充默认参数。 所以上面这段代码和下面这代代码是等价的。
import {
DEFAULT_DICT,
DEFAULT_HMM_DICT,
DEFAULT_IDF_DICT,
DEFAULT_STOP_WORD_DICT,
load,
} from "nodejieba";
load({
dict: DEFAULT_DICT,
hmmDict: DEFAULT_HMM_DICT,
userDict: "./test/testdata/userdict.utf8",
idfDict: DEFAULT_IDF_DICT,
stopWordDict: DEFAULT_STOP_WORD_DICT,
});
词典说明
- dict: 主词典,带权重和词性标签,建议使用默认词典。
- hmmDict: 隐式马尔科夫模型,建议使用默认词典。
- userDict: 用户词典,建议自己根据需要定制。
- idfDict: 关键词抽取所需的 idf 信息。
- stopWordDict: 关键词抽取所需的停用词列表。
词性标注
import { tag } from "nodejieba";
console.log(tag("红掌拨清波"));
//[ { word: '红掌', tag: 'n' },
// { word: '拨', tag: 'v' },
// { word: '清波', tag: 'n' } ]
更详细的其他用法请看 测试案例
关键词抽取
import { extract, textRankExtract } from "nodejieba";
const topN = 4;
console.log(extract("升职加薪,当上CEO,走上人生巅峰。", topN));
//[ { word: 'CEO', weight: 11.739204307083542 },
// { word: '升职', weight: 10.8561552143 },
// { word: '加薪', weight: 10.642581114 },
// { word: '巅峰', weight: 9.49395840471 } ]
console.log(textRankExtract("升职加薪,当上CEO,走上人生巅峰。", topN));
//[ { word: '当上', weight: 1 },
// { word: '不用', weight: 0.9898479330698993 },
// { word: '多久', weight: 0.9851260595435759 },
// { word: '加薪', weight: 0.9830464899847804 },
// { word: '升职', weight: 0.9802777682279076 } ]
更详细的其他用法请看 test/demo.js
Node.js 支持
v16
v18
v20
应用
- 支持中文搜索的 gitbook 插件: gitbook-plugin-search-pro
- 汉字拼音转换工具: pinyin
相关项目
性能评测
性能杠杠的,应该是目前性能最好的 Node.js 中文分词库,没有之一。 详见: Jieba 中文分词系列性能评测
在线演示
http://cppjieba-webdemo.herokuapp.com/ (chrome is suggested)
NodeJieba 在 Windows 上面的一系列安装问题和斗争成功过程参考
- win10 X64, VS2013, nodejieba@2.2.2 编译不成功
- version 2.2.2 Can't build on Win 10 x64
- nodejieba 在 win7 下的安装问题,有进展了
- win10 npm 安装报错
客服
Email: i@yanyiwu.com
作者
Contributors
Code Contributors
This project exists thanks to all the people who contribute.
<a href="https://github.com/yanyiwu/nodejieba/graphs/contributors"><img src="https://opencollective.com/nodejieba/contributors.svg?width=890&button=false" /></a>
Financial Contributors
Become a financial contributor and help us sustain our community. [Contribute]
Individuals
<a href="https://opencollective.com/nodejieba"><img src="https://opencollective.com/nodejieba/individuals.svg?width=890"></a>
Organizations
Support this project with your organization. Your logo will show up here with a link to your website. Contribute
<a href="https://opencollective.com/nodejieba/organization/0/website"><img src="https://opencollective.com/nodejieba/organization/0/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/1/website"><img src="https://opencollective.com/nodejieba/organization/1/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/2/website"><img src="https://opencollective.com/nodejieba/organization/2/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/3/website"><img src="https://opencollective.com/nodejieba/organization/3/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/4/website"><img src="https://opencollective.com/nodejieba/organization/4/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/5/website"><img src="https://opencollective.com/nodejieba/organization/5/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/6/website"><img src="https://opencollective.com/nodejieba/organization/6/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/7/website"><img src="https://opencollective.com/nodejieba/organization/7/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/8/website"><img src="https://opencollective.com/nodejieba/organization/8/avatar.svg"></a> <a href="https://opencollective.com/nodejieba/organization/9/website"><img src="https://opencollective.com/nodejieba/organization/9/avatar.svg"></a>