Project Icon

pytextclassifier

PyTextClassifier:支持多种文本分类和聚类算法的高性能工具库

PyTextClassifier是一款高性能的Python工具库,提供多种文本分类和聚类算法,支持二分类、多分类、多标签分类和Kmeans聚类。适用于情感分析和文本风险分类,设计简明易用,算法高效清晰。支持句子和文档级的文本任务,兼容英文和中文文本。包含FastText、TextCNN、TextRNN和BERT等深度学习模型,适合各类生产环境。

PyTextClassifier 项目介绍

简介

PyTextClassifier 是一个开源的 Python 文本分类工具包,专为满足生产环境中的文本分析需求而设计。它主要应用于情感极性分析和文本风险分类,并支持多种分类算法和聚类算法。该工具包能够处理句子和文档级的分类任务,涵盖二分类、多分类、多标签分类、多层级分类和 Kmeans 聚类等任务,且在 Python 3 环境下运行。

特性

PyTextClassifier 的特点在于其算法的清晰性、高性能以及可定制的语料库。它提供多种模型供选择,包括传统机器学习算法和深度学习模型。

分类器

  • Logistic Regression(逻辑回归)
  • Random Forest(随机森林)
  • Decision Tree(决策树)
  • K-Nearest Neighbours(K近邻)
  • Naive Bayes(朴素贝叶斯)
  • XGBoost
  • Support Vector Machine (SVM)(支持向量机)
  • TextCNN
  • TextRNN
  • FastText
  • BERT

聚类

  • MiniBatchKmeans

在功能丰富的同时,PyTextClassifier 的内部模块设计为低耦合,支持惰性加载模型,提供简单易用的字典发布,极大地方便了用户的使用。

安装

用户可以通过以下命令安装 PyTextClassifier:

pip3 install torch  # conda install pytorch
pip3 install pytextclassifier

或通过克隆 Git 仓库进行安装:

git clone https://github.com/shibing624/pytextclassifier.git
cd pytextclassifier
python3 setup.py install

使用

PyTextClassifier 可以轻松实现文本分类任务,以 ClassicClassifier 为例,通过导入工具包进行模型训练、保存、预测和评估。以下代码展示了如何进行英语和中文文本分类。

英文文本分类

from pytextclassifier import ClassicClassifier

if __name__ == '__main__':
    m = ClassicClassifier(output_dir='models/lr', model_name_or_model='lr')
    data = [
        ('education', 'Student debt to cost Britain billions within decades'),
        ('education', 'Chinese education for TV experiment'),
        ('sports', 'Middle East and Asia boost investment in top level sports'),
        ('sports', 'Summit Series look launches HBO Canada sports doc series: Mudhar')
    ]
    m.train(data)
    m.load_model()
    predict_label, predict_proba = m.predict(['Abbott government spends $8 million on higher education media blitz'])
    print(f'predict_label: {predict_label}, predict_proba: {predict_proba}')
    test_data = [
        ('education', 'Abbott government spends $8 million on higher education media blitz'),
        ('sports', 'Middle East and Asia boost investment in top level sports'),
    ]
    acc_score = m.evaluate_model(test_data)
    print(f'acc_score: {acc_score}')

运行结果:

ClassicClassifier instance (LogisticRegression(fit_intercept=False), stopwords size: 2438)
predict_label: ['education'], predict_proba: [0.5378236358492112]
acc_score: 1.0

中文文本分类

from pytextclassifier import ClassicClassifier

if __name__ == '__main__':
    m = ClassicClassifier(output_dir='models/lr-toy', model_name_or_model='lr')
    data = [
        ('education', '名师指导托福语法技巧:名词的复数形式'),
        ('education', '中国高考成绩海外认可 是“狼来了”吗?'),
        ('sports', '图文:法网孟菲尔斯苦战进16强 孟菲尔斯怒吼'),
        ('sports', '四川丹棱举行全国长距登山挑战赛 近万人参与'),
    ]
    m.train(data)
    print(m)
    m.load_model()
    predict_label, predict_proba = m.predict(['福建春季公务员考试报名18日截止 2月6日考试'])
    print(f'predict_label: {predict_label}, predict_proba: {predict_proba}')
    test_data = [
        ('education', '福建春季公务员考试报名18日截止 2月6日考试'),
        ('sports', '意甲首轮补赛交战记录:米兰客场8战不败国米10年连胜'),
    ]
    acc_score = m.evaluate_model(test_data)
    print(f'acc_score: {acc_score}')

联系方式

如果您对 PyTextClassifier 有任何疑问或建议,欢迎通过以下方式联系我们:

  • 通过 GitHub 提交问题:
  • 发送邮件给项目维护者:xuming624@qq.com
  • 加入微信交流群,微信号:xuming624,备注:"姓名-公司名-NLP" 以获得入群邀请。

引用

如果您在研究中使用了 PyTextClassifier ,请使用以下格式进行引用:

APA 格式:

Xu, M. Pytextclassifier: Text classifier toolkit for NLP (Version 1.2.0) [Computer software]. https://github.com/shibing624/pytextclassifier

BibTeX 格式:

@misc{Pytextclassifier,
  title={Pytextclassifier: Text classifier toolkit for NLP},
  author={Xu Ming},
  year={2022},
  howpublished={\url{https://github.com/shibing624/pytextclassifier}},
}

PyTextClassifier 是一个强大且易用的文本分类工具,对于需要处理文本数据的应用场景非常有帮助。无论是情感分析还是其他文本分类任务,PyTextClassifier 都提供了灵活的解决方案。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号