使用Python+jieba和java+庖丁分词在Spark集群上进行中文分词统计

2023-12-13 09:32

本文主要是介绍使用Python+jieba和java+庖丁分词在Spark集群上进行中文分词统计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在前边的话:

        本篇博客也是在做豆瓣电影数据的分析过程中,需要对影评信息和剧情摘要信息进行分析而写的一篇博客

        以前学习Hadoop时,感觉做中文分词也没那么麻烦,但是到了Spark,却碰到了诸多困难,但幸好最终都解决了这些问题,而得到了正确的结果,这里我们不解释具体的spark语法之类的,着重于解决中文分词统计这个问题

        同步github地址:点击查看


1:Python+jieba

      使用Python版本的spark,首先想到的便是jieba分词,这里结合python的jieba分词和Spark对文件内容进行分词和词频统计,使用的样例数据依旧豆瓣电影的影评数据,这里只是采用了大鱼海棠的影评信息进行分词。

      数据样例的格式如下:

26051523        根据真实事件改编,影片聚焦1973年智利政变时期,一对年轻的德国夫妇丹尼尔与莱娜反抗智利军政府统领、独裁者皮诺切特的故事。当时正值智利政变的高潮期,丹尼尔被皮诺切特的手下绑架到一个被称为“尊严殖民地”的秘密基地。那儿正是前德国纳粹分子逃亡智利所建的聚集地,而军政府武装进行着大量的刑讯工作与秘密人体实验,被绑架的人从来没有一个曾活着逃出“殖民地”。然而丹尼尔的妻子莱娜没有放弃,她找到了基地所在,并计划救出丈夫。

     需要注意的是:如果去掉下面函数中的combine函数,则正常保存统计结果,显示的形式大致是这样的

     

     而这里的combine函数就是为了解决这个问题,最终的统计结果为

     

[html]  view plain copy
在CODE上查看代码片 派生到我的代码片
  1. <span style="font-family:Microsoft YaHei;font-size:14px;">#-*-coding:utf-8-*-  
  2. from pyspark import SparkConf, SparkContext  
  3.   
  4. import jieba  
  5.   
  6. def split(line):  
  7.     word_list = jieba.cut(line.strip().split("\t")[1])  #进行中文分词  
  8.     ls =[]  
  9.     for word in word_list:  
  10.         if len(word)>1:      #过滤掉单音节词  
  11.             ls.append(word)  
  12.     return ls  
  13.   
  14. def combine(line):        #去除保存结果中的括号和解=解决中文编码显示的问题  
  15.     result = ""  
  16.     result +=line[0]+"\t"+str(line[1])   #让数字在前,方便统计  
  17.     return result  
  18.   
  19. def main(sc):  
  20.     text = sc.textFile("/file/douban_movie_data/movie_summary.txt")  
  21.     word_list = text.map(split).collect() #保存为列表  
  22.     count = sc.parallelize(word_list[0]) #返回列表中的第一个元素  
  23.     results = count.map(lambda w:(w,1)).reduceByKey(lambda x,y:x+y).map(combine).sortByKey().saveAsTextFile("/file/douban_movie_data/result")  
  24.     print "succeed"  
  25.   
  26. if __name__=="__main__":  
  27.     conf = SparkConf().setAppName("wordSplit")  
  28.     conf.setMaster("local")  
  29.     scSparkContext(conf = conf)  
  30.     main(sc)</span>  


2:Java+Scala+庖丁分词

       网上搜了一遍,有使用ansj分词的,但是瞄了一遍,不懂,于是还是回归到了庖丁分词,整体的程序分为两部分,一个是Java+庖丁分词程序,一个是Scala提交spark的统计程序,具体代码和解释如下

       至于如何使用Idea+Spark构建开发环境请移步:点击阅读

       庖丁分词等中文分词比较请移步:点击阅读

          这里需要注意的是:庖丁分词的字典库的配置问题(下图红线所示),正常情况下,程序打成jar包在spark集群上运行会报出各种错误,但主要是两个方面,一个是spark集群的内存问题(我用的是自己电脑的虚拟机,视具体配置而定),二是字典库的路径问题,我这里是把dic放在集群上每台机器的一个指定的相同的目录,同时把jar包在放在集群上的每台机器上

            

tokens.java

[html]  view plain copy
在CODE上查看代码片 派生到我的代码片
  1. <span style="font-family:Microsoft YaHei;font-size:14px;">import java.io.IOException;  
  2. import java.io.StringReader;  
  3. import java.util.ArrayList;  
  4. import java.util.List;  
  5.   
  6. import net.paoding.analysis.analyzer.PaodingAnalyzer;  
  7.   
  8. import org.apache.lucene.analysis.Analyzer;  
  9. import org.apache.lucene.analysis.Token;  
  10. import org.apache.lucene.analysis.TokenStream;  
  11.   
  12. public class tokens {  
  13.     public static List<String> anaylyzerWords (String str){  
  14.         // TODO Auto-generated method stub  
  15.         //定义一个解析器    
  16.         Analyzer analyzer = new PaodingAnalyzer();  
  17.         //定义一个存放存词的列表  
  18.         List<String> list=new ArrayList<String>();  
  19.         //得到token序列的输出流  
  20.         TokenStream tokens = analyzer.tokenStream(str, new StringReader(str));  
  21.         try{  
  22.             Token t;  
  23.             while((t=tokens.next() ) !=null){  
  24.                 list.add(t.termText());  
  25.             }  
  26.         }catch(IOException e){  
  27.             e.printStackTrace();  
  28.         }  
  29.         return list;  
  30.     }  
  31.   
  32.     public static void main(String[] args){  
  33.         String text = "本思想就是在分词的同时进行句法、语义分析, 利用句法信息和语义信息来进行词性标注, " +  
  34.                 "以解决分词歧义现象。因为现有的语法知识、句法规则十分笼统、复杂, 基于语法和规则的分词" +  
  35.                 "法所能达到的精确度远远还不能令人满意, 目前这种分词系统还处在试验阶段。";  
  36.         List<String> list=tokens.anaylyzerWords(text);  
  37.         for(String s:list){  
  38.             System.out.println(s);  
  39.         }  
  40.   
  41.     }  
  42. }  </span>  


Analyzer.scala
[html]  view plain copy
在CODE上查看代码片 派生到我的代码片
  1. <span style="font-family:Microsoft YaHei;font-size:14px;">import org.apache.spark._  
  2. /**  
  3.   * Created by gaoyt on 2016/8/11.  
  4.   */  
  5. object Analyzer {  
  6.   def main(args: Array[String]): Unit = {  
  7.     val conf = new SparkConf().setAppName("my app").setMaster("spark://192.168.48.130:7077")  
  8.     val sc = new SparkContext(conf)  
  9.     val outputPath = "/file/douban_movie_data/summary"  
  10.     sc.addJar("/home/master/SparkApp/WordAnalyzer.jar")  
  11.     sc.textFile("/file/douban_movie_data/movie_summary.txt").map(x => {  
  12.       val list=tokens.anaylyzerWords(x)  
  13.       list.toString.replace("[", "").replace("]", "").split(",")  
  14.     }).flatMap(x => x.toList).map(x => (x.trim(),1)).reduceByKey(_+_).saveAsTextFile(outputPath)  
  15.   
  16.   }  
  17. }</span>  

最终的运行结果如下:


执行查看命令

[html]  view plain copy
在CODE上查看代码片 派生到我的代码片
  1. <span style="font-family:Microsoft YaHei;font-size:14px;">/opt/hadoop/bin/hdfs dfs -cat /file/douban_movie_data/summary/part-00001</span>  

这篇关于使用Python+jieba和java+庖丁分词在Spark集群上进行中文分词统计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/487955

相关文章

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与