自然语言处理系列三十八》词频-逆文档频率TF-IDF》Python代码实现

server/2024/10/18 10:13:57/
aidu_pl">

注:此文章内容均节选自充电了么创始人,CEO兼CTO陈敬雷老师的新书自然语言处理原理与实战》(人工智能科学与技术丛书)【陈敬雷编著】【清华大学出版社】

文章目录

  • 自然语言处理系列三十八
    • Python代码实现词频-逆文档频率(TF-IDF)
      • 条件随机场(CRF)算法原理
  • 总结

自然语言处理系列三十八

Python代码实现词频-逆文档频率(TF-IDF)

请两篇文章讲了算法原理和Java实现TF-IDF,本篇文章使用Python代码实现。
9.2 Python代码实现TF-IDF
TF-IDF基于Python代码如9.2所示。
【代码9.2】 TFIDF.py

python">#!/usr/bin/python
# -*- coding: utf-8 -*-
#__author__ = '陈敬雷'
import os
import codecs
import math
import operator
print("充电了么 - 专注上班族职业培训和职业技能提升充电学习的在线教育平台")
""" 
词频-逆文档频率(TF-IDF)
"""
def fun(filepath):  # 遍历文件夹中的所有文件,返回文件listarr = []for root, dirs, files in os.walk(filepath):for fn in files:arr.append(root+"\\"+fn)return arrdef wry(txt, path):  # 写入txt文件f = codecs.open(path, 'a', 'utf8')f.write(txt)f.close()return pathdef read(path):  # 读取txt文件,并返回listf = open(path, encoding="utf8")data = []for line in f.readlines():data.append(line)return datadef toword(txtlis):  # 将一片文章按照‘/’切割成词表,返回listwordlist = []alltxt = ''for i in txtlis:alltxt = alltxt+str(i)ridenter = alltxt.replace('\n', '')wordlist = ridenter.split('/')return wordlistdef getstopword(path):  # 获取停用词表swlis = []for i in read(path):outsw = str(i).replace('\n', '')swlis.append(outsw)return swlisdef getridofsw(lis, swlist):  # 去除文章中的停用词afterswlis = []for i in lis:if str(i) in swlist:continueelse:afterswlis.append(str(i))return afterswlisdef freqword(wordlis):  # 统计词频,并返回字典freword = {}for i in wordlis:if str(i) in freword:count = freword[str(i)]freword[str(i)] = count+1else:freword[str(i)] = 1return freworddef corpus(filelist, swlist):  # 建立语料库alllist = []for i in filelist:afterswlis = getridofsw(toword(read(str(i))), swlist)alllist.append(afterswlis)return alllistdef wordinfilecount(word, corpuslist):  # 查出包含该词的文档数count = 0  # 计数器for i in corpuslist:for j in i:if word in set(j):  # 只要文档出现该词,这计数器加1,所以这里用集合count = count+1else:continuereturn countdef tf_idf(wordlis, filelist, corpuslist):  # 计算TF-IDF,并返回字典outdic = {}tf = 0idf = 0dic = freqword(wordlis)outlis = []for i in set(wordlis):tf = dic[str(i)]/len(wordlis)  # 计算TF:某个词在文章中出现的次数/文章总词数# 计算IDF:log(语料库的文档总数/(包含该词的文档数+1))idf = math.log(len(filelist)/(wordinfilecount(str(i), corpuslist)+1))tfidf = tf*idf  # 计算TF-IDFoutdic[str(i)] = tfidforderdic = sorted(outdic.items(), key=operator.itemgetter(1), reverse=True)  # 给字典排序return orderdicdef befwry(lis):  # 写入预处理,将list转为stringoutall = ''for i in lis:ech = str(i).replace("('", '').replace("',", '\t').replace(')', '')outall = outall+'\t'+ech+'\n'return outalldef main():#停用词是出现次数最多的词比如"的"、"是"、"在"----这一类最常用的词。swpath = r'stopwords.txt'#停用词表路径文件,内容每个停用词占用一行swlist = getstopword(swpath)  # 获取停用词表列表filepath = r'D:\充电了么TFIDF'#输入的文件夹,文件夹下面有多个文档文件filelist = fun(filepath)  # 获取文件列表wrypath = r'TFIDF.txt'#输出结果文件corpuslist = corpus(filelist, swlist)  # 建立语料库outall = ''for i in filelist:afterswlis = getridofsw(toword(read(str(i))), swlist)  # 获取每一篇已经去除停用的词表tfidfdic = tf_idf(afterswlis, filelist, corpuslist)  # 计算TF-IDFtitleary = str(i).split('\\')title = str(titleary[-1]).replace('utf8.txt', '')echout = title+'\n'+befwry(tfidfdic)print(title+' is ok!')outall = outall+echoutprint(wry(outall, wrypath)+' 计算完成并输出到文件!')if __name__ == '__main__':main()

条件随机场(CRF)算法原理

条件随机场(CRF)是Conditional Random Fields的缩写,即条件随机域,是Lafferty于2001年,在最大熵模型和隐马尔科夫模型的基础上,提出的一种判别式概率无向图学习模型,是一种用于标注和切分有序数据的条件概率模型,近年来在分词、词性标注和命名实体识别等序列标注任务中取得了很好的效果。也就是说要理解条件随机场需要先了解马尔可夫链、隐马尔可夫模型(HMM)的一些基本概念。下一篇文章详细讲解,敬请关注!

总结

此文章有对应的配套新书教材和视频:

【配套新书教材】
自然语言处理原理与实战》(人工智能科学与技术丛书)【陈敬雷编著】【清华大学出版社】
新书特色:本书从自然语言处理基础开始,逐步深入各种NLP热点前沿技术,使用了Java和Python两门语言精心编排了大量代码实例,契合公司实际工作场景技能,侧重实战。
全书共分为19章,详细讲解中文分词、词性标注、命名实体识别、依存句法分析、语义角色标注、文本相似度算法、语义相似度计算、词频-逆文档频率(TF-IDF)、条件随机场、新词发现与短语提取、搜索引擎Solr Cloud和Elasticsearch、Word2vec词向量模型、文本分类、文本聚类、关键词提取和文本摘要、自然语言模型(Language Model)、分布式深度学习实战等内容,同时配套完整实战项目,例如对话机器人实战、搜索引擎项目实战、推荐算法系统实战。
本书理论联系实践,深入浅出,知识点全面,通过阅读本书,读者不仅可以理解自然语言处理的知识,还能通过实战项目案例更好地将理论融入实际工作中。

【配套视频】
自然语言处理NLP原理与实战 视频教程【陈敬雷】
视频特色:《自然语言处理NLP原理与实战》包含了互联网公司前沿的热门算法的核心原理,以及源码级别的应用操作实战,直接讲解自然语言处理的核心精髓部分,自然语言处理从业者或者转行自然语言处理者必听视频!

上一篇:自然语言处理系列三十七》词频-逆文档频率TF-IDF》Java代码实现
下一篇:自然语言处理系列三十九》条件随机场(CRF)算法原理


http://www.ppmy.cn/server/104433.html

相关文章

PyTorch 基础学习(13)- 混合精度训练

系列文章: 《PyTorch 基础学习》文章索引 基本概念 混合精度训练是深度学习中一种优化技术,旨在通过结合高精度(torch.float32)和低精度(如 torch.float16 或 torch.bfloat16)数据类型的优势,…

基于x86 平台opencv的图像采集和seetaface6的性别识别功能

目录 一、概述二、环境要求2.1 硬件环境2.2 软件环境三、开发流程3.1 编写测试3.2 配置资源文件3.2 验证功能一、概述 本文档是针对x86 平台opencv的图像采集和seetaface6的性别识别功能,opencv通过摄像头采集视频图像,将采集的视频图像送给seetaface6的性别识别模块从而实现…

聚类分析|距离与相似系数|层次聚类|K均值聚类|SPSS及Matlab

聚类分析问题描述 聚类分析问题描述 人类认识世界的方法之一就是将事物按照各种属性或特征分成若干类别。 物以类聚、人以群分。分类方法多种多样,简单直接的如高、矮、胖瘦。使用的信息量小,但对类别界限附近的案例,分类结果不一定合适。 …

PHP开发过程中常见问题快速解决

1.PHP解决文件名不合法,无法创建 文件名称不能含有 /\:*?"<>|符号&#xff0c;直接替换关键词就OK了 $search array(*,$,\\,/,"",",*,?,:,<,>,|, ,[,],【,】,(,),&#xff08;,&#xff09;); $name"1:.php"; $new_namestr_repla…

MySQL存储过程详细讲解和常见问题及性能优化

MySQL存储过程详细讲解和常见问题及性能优化 在MySQL中&#xff0c;存储过程是一种强大的功能&#xff0c;能够提高数据处理效率并封装复杂的业务逻辑。本文将详细介绍MySQL存储过程的基础语法和常见问题及解决方式&#xff0c;特别是在批量处理数据时如何结合事务提高性能&am…

PXE 高效批量网络装机

部署 PXE 远程安装服务 规模化&#xff1a;同时装配多台服务器&#xff1b; 自动化&#xff1a;安装系统、配置各种服务&#xff1b; 远程实现&#xff1a;不需要光盘、U 盘等安装介质 搭建 PXE 远程安装服务器 准备 CentOS 7 安装源 CentOS 7 的网络安装源一般通过 HTTP…

FDD与TDD——两种双工模式

目录 一、FDD&#xff08;频分双工&#xff09; 1. 作用 2. 原理 3. 特点 二、TDD&#xff08;时分双工&#xff09; 1. 作用 2. 原理 3. 特点 总结 FDD&#xff08;频分双工&#xff0c;Frequency Division Duplexing&#xff09;和TDD&#xff08;时分双工&#xf…

专家翻译和本地化对中国商品推广的影响

随着中国企业不断扩大其在全球市场的影响力&#xff0c;有效推广其产品的需求从未如此重要。中国产品在海外成功推广的一个重要因素是专家翻译和本地化。这些服务不仅仅是将文本从一种语言转换为另一种语言&#xff1b;它们涉及调整产品和营销策略&#xff0c;以适应目标市场的…