一、案例综述
案例编号:102006
案例名称:中英文垃圾短信过滤
作者姓名(或单位、或来源):朱江
案例所属行业:J631 电信
案例所用软件:R
案例包含知识点:中英文文本数据处理 朴素贝叶斯分类
案例描述:
目前全球范围内手机已经不成不可替代的生活必需品,而短信和微信成为人们日常沟通的主要方式,其中广告商利用短信服务(SMS)文本信息,以潜在消费者为目标,给他们发送不需要的广告信息。目前垃圾短信可以实现对固定区域内特定手机号码段的用户群发,并且手机号信息泄露极其严重。这些都导致手机用户特别是老的手机用户收到垃圾短信的频率较高,故垃圾短信和正常短信的分类不管是对于运营商还是对于客户来说都是较为有利的工具。
朴素贝叶斯已经成功的用于垃圾邮件的过滤,所以它很有可能用于垃圾短信的过滤。然而,相对于垃圾邮件来说,垃圾短信的自动过滤有额外的挑战:由于短信文本数的限制,所以一条短信是否是垃圾信息的文本量减少了;短信的口语化导致文本可能极其不规整,尤其是中文文本,会带来文本处理的难度;缩写的形式在中英文文本中都较为普遍,而且中文文本中新兴词汇的使用,都会模糊合法信息和垃圾信息的界限。
本案例包含已经添加好标签的英文短信数据和中文短信数据,英文数据有5559条,可以进行全数据处理,数据文件不是很大。而中文短信有80万条的信息,信息量较大,在处理过程中会生成130多G的稀疏矩阵,远超出R的内存限制,且中文文本处理更为麻烦,故这里按照短信长度正常短信和垃圾短信分别取前1000条进行分类建模
本案例知识点没有办法细分,因为文本处理过程中生成的文本文件都比较大,会加大内存消耗,且建模前的稀疏矩阵存储读取都需要转格式较为繁琐,故这里我们英文短信分类作为一个知识点,中文短信分类作为一个知识点。
本案例共包含两个个知识点
1英文短信文本读取、清洗、词云、建模、评估
2中文短信文本读取、清洗、词云、建模、评估
案例执行形式:
单人上机
二、案例知识点
知识点1:
知识点名称:英文短信文本读取、清洗、词云、建模、评估
知识点所属工作角色:文本处理 文本挖掘 词云 朴素贝叶斯分类 分类模型评估
知识点背景:英文文本挖掘过程中常见的文本预处理,朴素贝叶斯属于一种比较简单的分类模型。
知识点描述:
涉及到英文文本处理中的去除无关字符、大小写转换、去除停用词、去除空白、词汇修剪(stem)
知识点关键词:
文本处理 文本挖掘 词云 朴素贝叶斯分类 分类模型评估
知识点所用软件:
Rstudio
操作目的:
英文短信文本读取、清洗、词云、建模、评估
知识点素材(包括数据):
sms_spam.csv
操作步骤:
读取文件,将其中的type列转化为因子
可见其中正常短信共有4812条,垃圾短信有747条。
将所有的文本信息构建成语料库,并且打印出未经处理的前十条信息
构建去除非子母类字符的函数,用空格替换
使用大写变小写、去除停用词、去除多余空格以及上面构建的函数转换语料库,并且观察转换后的前十条信息
将原数据分为训练集和测试集,其中训练集占75%,测试集占25%。
查看训练集和测试集中垃圾信息占比是否近似
可见占比都在13%左右
将语料库同样分为训练集测试集,方便后面构建文档词矩阵使用
分别对所有训练集,训练集中垃圾信息,训练集中正常信息创建词云
所有训练集信息的词云:
训练集中的垃圾信息的词云:
训练集中正常信息的词云:
筛选出现在大于等于5条短信中的词,由训练语料库和测试语料库生成文档词矩阵(稀疏矩阵),根据筛选出的词筛选稀疏矩阵的列
将文档词矩阵中所有大于0的数字替换为“yes”,0替换为“no”,得到训练矩阵train和测试矩阵test
使用朴素贝叶斯对训练矩阵建模,通过测试矩阵预测出分类,然后评估模型的性能
得到的结果中,正常短信中错误的将垃圾信息预测为正常信息的占比为12.7%,垃圾短信中错误的将正常信息预测为垃圾信息的占比为85%,可见模型性能一般,需要更多的初期工作,例如更多的数据采集,词汇处理上更多的选择等等
操作结果:
得到训练集中不同类型短信的词云;将测试集的短信分类。
知识点小结:
本知识点显示了英文文本清洗及转换为文档词矩阵的全套流程,以及使用朴素贝叶斯进行分类和评估的全套流程。
知识点2:
知识点名称:中文短信文本读取、清洗、词云、建模、评估
知识点所属工作角色:
文本处理 文本挖掘 词云 朴素贝叶斯分类 分类模型评估
知识点背景:
中文文本挖掘过程中常见的文本预处理,朴素贝叶斯属于一种比较简单的分类模型。
知识点描述
涉及到中文文本处理中的去除无关字符、去除停用词、去除空白、分词
知识点关键词:
文本处理 文本挖掘 词云 朴素贝叶斯分类 分类模型评估
知识点所用软件:
Rstudio
操作目的:
中文短信文本读取、清洗、词云、建模、评估
知识点素材(包括数据):
sms_labelled.txt stop.txt
操作步骤:
操作步骤:
读取文件,用readLines按行读取
抽取每行文本中的标签信息、短信信息、计算短信长度、合并成一个表格
可见其中第一列是标签,0表示正常信息,1表示垃圾信息
按文本长度由长到短排列所有信息,选取正常信息和垃圾信息中的前一千条
将标签变量type0重新命名为“ham”和“spam”
训练集中的垃圾信息的词云:
训练集中正常信息的词云:
筛选出现在大于等于5条短信中的词,由训练语料库和测试语料库生成文档词矩阵(稀疏矩阵),根据筛选出的词筛选稀疏矩阵的列
将文档词矩阵中所有大于0的数字替换为“yes”,0替换为“no”,得到训练矩阵train和测试矩阵test
使用朴素贝叶斯对训练矩阵建模,通过测试矩阵预测出分类,然后评估模型的性能
得到的结果中,虽然只有200条短信,正常短信中错误的将垃圾信息预测为正常信息的占比为25%,垃圾短信中错误的将正常信息预测为垃圾信息的占比为15.5%,可见模型性能较英文模型有了不错的提升
操作结果:
得到训练集中不同类型短信的词云;将测试集的短信分类。
知识点小结:
本知识点显示了中文文本清洗及转换为文档词矩阵的全套流程,以及使用朴素贝叶斯进行分类和评估的全套流程。
在词云中观察到有乱码,可能是由于txt存储类型不是UTF-8编码,可以打开txt源文件另存为指定编码来处理。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在数据驱动决策的时代,掌握多样的数据分析方法,就如同拥有了开启宝藏的多把钥匙,能帮助我们从海量数据中挖掘出关键信息,本 ...
2025-03-06在备考 CDA 考试的漫漫征途上,拥有一套契合考试大纲的优质模拟题库,其重要性不言而喻。它恰似黑夜里熠熠生辉的启明星,为每一 ...
2025-03-05“纲举目张,执本末从。”若想在数据分析领域有所收获,一套合适的学习教材至关重要。一套优质且契合需求的学习教材无疑是那关 ...
2025-03-04以下的文章内容来源于刘静老师的专栏,如果您想阅读专栏《10大业务分析模型突破业务瓶颈》,点击下方链接 https://edu.cda.cn/go ...
2025-03-04在现代商业环境中,数据分析师的角色愈发重要。数据分析师通过解读数据,帮助企业做出更明智的决策。因此,考取数据分析师证书成为了许多人提升职业竞争力的选择。本文将详细介绍考取数据分析师证书的过程,包括了解证书种类和 ...
2025-03-03在当今信息化社会,大数据已成为各行各业不可或缺的宝贵资源。大数据专业应运而生,旨在培养具备扎实理论基础和实践能力,能够应 ...
2025-03-03数据分析师认证考试全面升级后,除了考试场次和报名时间,小伙伴们最关心的就是报名费了,报 ...
2025-03-032025年刚开启,知乎上就出现了一个热帖: 2024年突然出现的经济下行,使各行各业都感觉到压力山大。有人说,大环境越来越不好了 ...
2025-03-03大数据分析师培训旨在培养学员掌握大数据分析的基础知识、技术及应用能力,以适应企业对数据分析人才的需求。根据不同的培训需求 ...
2025-03-03小伙伴们,最近被《哪吒2》刷屏了吧!这部电影不仅在国内掀起观影热潮,还在全球范围内引发了关注,成为中国电影崛起的又一里程 ...
2025-03-03以下的文章内容来源于张彦存老师的专栏,如果您想阅读专栏《Python 数据可视化 18 讲(PyEcharts、Matplotlib、Seaborn)》,点 ...
2025-02-28最近,国产AI模型DeepSeek爆火,其创始人梁文峰走进大众视野。《黑神话:悟空》制作人冯骥盛赞DeepSeek为“国运级别的科技成果” ...
2025-02-271.统计学简介 听说你已经被统计学劝退,被Python唬住……先别着急划走,看完这篇再说! 先说结论,大多数情况下的学不会都不是知 ...
2025-02-27“我们的利润率上升了,但销售额却没变,这是为什么?” “某个业务的市场份额在下滑,到底是什么原因?” “公司整体业绩稳定, ...
2025-02-26在数据分析工作中,你可能经常遇到这样的问题: 从浏览到消费的转化率一直很低,那到底该优化哪里呢? 如果你要投放广告该怎么 ...
2025-02-25近来deepseek爆火,看看deepseek能否帮我们快速实现数据看板实时更新。 可以看出这对不知道怎么动手的小白来说是相当友好的,尤 ...
2025-02-25挖掘用户价值本质是让企业从‘赚今天的钱’升级为‘赚未来的钱’,同时让用户从‘被推销’变为‘被满足’。询问deepseek关于挖 ...
2025-02-25在当今这个数据驱动的时代,几乎每一个业务决策都离不开对数据的深入分析。而其中,指标波动归因分析更是至关重要的一环。无论是 ...
2025-02-25以下文章来源于数有道 ,作者数据星爷 SQL查询是数据分析工作的基础,也是CDA数据分析师一级的核心考点,人工智能时代,AI能为 ...
2025-02-25“最近复购率一直在下降,我们的营销力度不小啊,为什么用户还是走了?” “是不是广告投放的用户质量不高?还是我们的产品问题 ...
2025-02-25