input_str = """
There are some people who think love is sex
And marriage
And six o'clock-kisses
And children,
And perhaps it is,
Miss Lester.
But do you know what I think?
I think love is a touch and yet not a touch
"""
input_str = input_str.lower()
print(input_str)
结果如下: & K4 ?- Z, U6 ~" \( _4 X
; D% k; v1 S5 K& H7 ?% `7 T 2、删除或者提取文本中出现的数字7 N! |6 f1 `$ w* }8 [3 f
如果文本中的数字与文本分析无关的话,那就删除这些数字。 ) H4 Z) r' i+ v* T. w
# 从Github下载停用词数据 https://github.com/zhousishuo/stopwords
import jieba
import re
# 读取用于测试的文本数据 用户评论
with open('comments.txt') as f:
data = f.read()
# 文本预处理 去除一些无用的字符 只提取出中文出来
new_data = re.findall('[\u4e00-\u9fa5]+', data, re.S)
new_data = "/".join(new_data)
# 文本分词 精确模式
seg_list_exact = jieba.cut(new_data, cut_all=False)
# 加载停用词数据
with open('stop_words.txt', encoding='utf-8') as f:
# 获取每一行的停用词 添加进集合
con = f.read().split('\n')
stop_words = set()
for i in con:
stop_words.add(i)
# 列表解析式 去除停用词和单个词
result_list = [word for word in seg_list_exact if word not in stop_words and len(word) > 1]
result_list
结果如下:8 C/ T7 m8 \* g! ^1 |# v
5 w. y: T% h) e+ S, e. ^/ T# A
首先读取用于测试的文本数据,该数据是爬取的商品评论,这一类数据通常有很多无意义的字词和符号,通过正则表达式滤除掉无用的符号,只提取出中文出来。使用 jieba 库进行文本分词,加载停用词数据到集合,然后一行列表解析式滤除停用词和单个词,这样效率很高。停用词数据可以下载一些公开的,再根据实际文本处理需要,添加字词语料进去,使滤除效果更好。 4 x4 r+ M4 q) {' e8 X) \Github下载停用词数据:https://github.com/zhousishuo/stopwords/ j# M B% T4 q& V" I3 a6 c2 c* Z
SnowNLP是一个 Python 写的类库,可以方便的处理中文文本内容,是受到了 TextBlob 的启发而写的,由于现在大部分的自然语言处理库基本都是针对英文的,于是写了一个方便处理中文的类库,并且和 TextBlob 不同的是,这里没有用NLTK,所有的算法都是自己实现的,并且自带了一些训练好的字典。注意本程序都是处理的 unicode 编码,所以使用时请自行 decode 成 unicode 编码。 " _$ R1 S! U6 A! v4 o; x% | 使用 SnowNLP 处理中文文本数据非常方便,以词性标注和关键词提取为例: 1 C# T+ W# @* Y. z4 ?' s" B- w