广告位联系
返回顶部
分享到

Python实现文本特征提取的方法

python 来源:互联网 作者:佚名 发布时间:2022-08-29 21:21:16 人浏览
摘要

1.字典文本特征提取 DictVectorizer() 1.1 one-hot编码 创建一个字典,观察如下数据形式的变化: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 import pandas as pd from sklearn.feature_extraction import DictVectorizer data = [{c

1.字典文本特征提取 DictVectorizer()

1.1 one-hot编码

创建一个字典,观察如下数据形式的变化:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

import pandas as pd

from sklearn.feature_extraction import DictVectorizer

 

 

data = [{'city': '洛阳', 'temperature': 39},

        {'city': '成都', 'temperature': 41},

        {'city': '宁波', 'temperature': 42},

        {'city': '佛山', 'temperature': 38}]

 

df1 = pd.DataFrame(data)

print(df1)

 

# one-hot编码 因为temperature是数值型的,所以会保留原始值,只有字符串类型的才会生成虚拟变量

df2 = pd.get_dummies(df1)

print(df2)

输出如下:

1.2 字典数据转sparse矩阵

使用DictVectorizer()创建字典特征提取模型

1

2

3

4

5

6

# 1.创建对象  默认sparse=True 返回的是sparse矩阵;  sparse=False  返回的是ndarray矩阵

transfer = DictVectorizer()

# 2.转化数据并训练

trans_data = transfer.fit_transform(data)

print(transfer.get_feature_names_out())

print(trans_data)

使用sparse矩阵没有显示0数据,节约了内存,更为简洁,这一点比ndarray矩阵更好。

2.英文文本特征提取

文本特征提取使用的是CountVectorizer文本特征提取模型,这里准备了一段英文文本(I have a dream)。统计词频并得到sparse矩阵,代码如下所示:

CountVectorizer()没有sparse参数,默认采用sparse矩阵格式。且可以通过stop_words指定停用词。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

from sklearn.feature_extraction.text import CountVectorizer

 

 

data = ["I have a dream that one day this nation will rise up and live out the true meaning of its creed",

        "We hold these truths to be self-evident, that all men are created equal",

        "I have a dream that one day on the red hills of Georgia, "

        "the sons of former slaves and the sons of former slave owners will be able to sit down together at the table of brotherhood",

        "I have a dream that one day even the state of Mississippi",

        " a state sweltering with the heat of injustice",

        "sweltering with the heat of oppression",

        "will be transformed into an oasis of freedom and justice",

        "I have a dream that my four little children will one day live in a nation where they will not be judged by the color of their skin but by the content of their character",

        "I have a dream today"]

 

 

# CountVectorizer文本特征提取模型

 

# 1.实例化  将"is"标记为停用词

c_transfer = CountVectorizer(stop_words=["is"])

 

# 2.调用fit_transform

c_trans_data = c_transfer.fit_transform(data)

 

 

# 打印特征名称

print(c_transfer.get_feature_names_out())

 

# 打印sparse矩阵

print(c_trans_data)

输出结果如下图所示:

3.中文文本特征提取

准备一段中文文本(data.txt),以水浒传中风雪山神庙情节为例:

1

2

3

4

大雪下的正紧,林冲和差拨两个在路上又没买酒吃处。早来到草料场外,看时,一周遭有些黄土墙,两扇大门。推开看里面时,七八间草房做着仓廒,四下里都是马草堆,中间两座草厅。到那厅里,只见那老军在里面向火。差拨说道:“管营差这个林冲来替你回天王堂看守,你可即便交割。”老军拿了钥匙,引着林冲,分付道:“仓廒内自有官司封记,这几堆草一堆堆都有数目。”老军都点见了堆数,又引林冲到草厅上。老军收拾行李,临了说道:“火盆、锅子、碗碟,都借与你。”林冲道:“天王堂内我也有在那里,你要便拿了去。”老军指壁上挂一个大葫芦,说道:“你若买酒吃时,只出草场,投东大路去三二里,便有市井。”老军自和差拨回营里来。

只说林冲就床上放了包裹被卧,就坐下生些焰火起来。屋边有一堆柴炭,拿几块来生在地炉里。仰面看那草屋时,四下里崩坏了,又被朔风吹撼,摇振得动。林冲道:“这屋如何过得一冬?待雪晴了,去城中唤个泥水匠来修理。”向了一回火,觉得身上寒冷,寻思:“却才老军所说五里路外有那市井,何不去沽些酒来吃?”便去包里取些碎银子,把花枪挑了酒葫芦,将火炭盖了,取毡笠子戴上,拿了钥匙,出来把草厅门拽上。出到大门首,把两扇草场门反拽上,锁了。带了钥匙,信步投东。雪地里踏着碎琼乱玉,迤逦背着北风而行。那雪正下得紧。

行不上半里多路,看见一所古庙。林冲顶礼道:“神明庇佑,改日来烧钱纸。”又行了一回,望见一簇人家。林冲住脚看时,见篱笆中挑着一个草帚儿在露天里。林冲径到店里,主人道:“客人那里来?”林冲道:“你认得这个葫芦么?”主人看了道:“这葫芦是草料场老军的。”林冲道:“如何便认的?”店主道:“既是草料场看守大哥,且请少坐。天气寒冷,且酌三杯权当接风。”店家切一盘熟牛肉,烫一壶热酒,请林冲吃。又自买了些牛肉,又吃了数杯。就又买了一葫芦酒,包了那两块牛肉,留下碎银子,把花枪挑了酒葫芦,怀内揣了牛肉,叫声相扰,便出篱笆门,依旧迎着朔风回来。看那雪,到晚越下的紧了。古时有个书生,做了一个词,单题那贫苦的恨雪:

广莫严风刮地,这雪儿下的正好。扯絮挦绵,裁几片大如栲栳。见林间竹屋茅茨,争些儿被他压倒。富室豪家,却言道压瘴犹嫌少。向的是兽炭红炉,穿的是绵衣絮袄。手捻梅花,唱道国家祥瑞,不念贫民些小。高卧有幽人,吟咏多诗草。

对中文提取文本特征,需要安装并使用到jieba库。使用该库将文本处理成为空格连接词语的格式,再使用CountVectorizer文本特征提取模型进行提取即可。

代码示例如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

import jieba

from sklearn.feature_extraction.text import CountVectorizer

 

 

# 将文本转为以空格相连的字符串

def cut_word(sent):

    return " ".join(list(jieba.cut(sent)))

 

 

# 将文本以行为单位,去除空格,并置于列表中。格式形如:["第一行","第二行",..."n"]

with open("./论文.txt", "r") as f:

    data = [line.replace("\n", "") for line in f.readlines()]

 

lis = []

# 将每一行的词汇以空格连接

for temp in data:

    lis.append(cut_word(temp))

 

transfer = CountVectorizer()

trans_data = transfer.fit_transform(lis)

print(transfer.get_feature_names())

# 输出sparse数组

print(trans_data)

# 转为ndarray数组(如果需要)

print(trans_data.toarray())

程序执行效果如下:

转换得到的ndarray数组形式(如果需要)如图所示:

4. TF-IDF 文本特征提取 TfidfVectorizer()

TF-IDF文本提取器可以用来评估一字词对于一个文件集或者一个语料库中的其中一份文件的重要程度。

代码展示如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

from sklearn.feature_extraction.text import TfidfVectorizer

import jieba

 

 

def cut_word(sent):

    return " ".join(list(jieba.cut(sent)))

 

 

with open("data.txt", "r") as f:

    data = [line.replace("\n", "") for line in f.readlines()]

 

lis = []

for temp in data:

    # print(cut_word(temp))

    lis.append(cut_word(temp))

 

 

transfer = TfidfVectorizer()

print(transfer.get_feature_names())

print(trans_data)

程序执行结果如下:


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/weixin_48964486/article/details/126333634
相关文章
  • Python Django教程之实现新闻应用程序

    Python Django教程之实现新闻应用程序
    Django是一个用Python编写的高级框架,它允许我们创建服务器端Web应用程序。在本文中,我们将了解如何使用Django创建新闻应用程序。 我们将
  • 书写Python代码的一种更优雅方式(推荐!)

    书写Python代码的一种更优雅方式(推荐!)
    一些比较熟悉pandas的读者朋友应该经常会使用query()、eval()、pipe()、assign()等pandas的常用方法,书写可读性很高的「链式」数据分析处理代码
  • Python灰度变换中伽马变换分析实现

    Python灰度变换中伽马变换分析实现
    1. 介绍 伽马变换主要目的是对比度拉伸,将图像灰度较低的部分进行修正 伽马变换针对的是对单个像素点的变换,也就是点对点的映射 形
  • 使用OpenCV实现迷宫解密的全过程

    使用OpenCV实现迷宫解密的全过程
    一、你能自己走出迷宫吗? 如下图所示,可以看到是一张较为复杂的迷宫图,相信也有人尝试过自己一点一点的找出口,但我们肉眼来解谜
  • Python中的数据精度问题的介绍

    Python中的数据精度问题的介绍
    一、python运算时精度问题 1.运行时精度问题 在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和
  • Python随机值生成的常用方法

    Python随机值生成的常用方法
    一、随机整数 1.包含上下限:[a, b] 1 2 3 4 import random #1、随机整数:包含上下限:[a, b] for i in range(10): print(random.randint(0,5),end= | ) 查看运行结
  • Python字典高级用法深入分析讲解
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python浅析多态与鸭子类型使用实例
    什么多态:同一事物有多种形态 为何要有多态=》多态会带来什么样的特性,多态性 多态性指的是可以在不考虑对象具体类型的情况下而直
  • Python字典高级用法深入分析介绍
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本

    Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本
    我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计