l_future_ 2023-01-05 18:49 采纳率: 50%
浏览 61
已结题

Python如何进行停用词、词性过滤、去掉长度为1的字

请问大家,对文本数据进行分词处理后,使用python怎么进行停用词处理和词性过滤(假设只保留名词、动词、形容词),并将长度为1的字符去掉,不知道怎么将这三种操作结合,希望各位帮忙。

  • 写回答

2条回答 默认 最新

  • ShowMeAI 2023-01-05 19:39
    关注

    给你写了一个参考示例代码,希望对你有帮助,望采纳

    # 导入必要的库
    import jieba.posseg as pseg
    
    # 加载停用词
    stopwords = set()
    with open("stopwords.txt", "r", encoding="utf-8") as f:
        for line in f:
            stopwords.add(line.strip())
    
    # 进行词性过滤和停用词处理
    filtered_words = []
    for word, pos in pseg.cut(text):
        # 只保留名词、动词、形容词
        if pos in {"n", "v", "a"}:
            # 去掉长度为1的字符
            if len(word) > 1:
                # 去除停用词
                if word not in stopwords:
                    filtered_words.append(word)
    
    # 打印结果
    print(filtered_words)
    
    • 代码使用了jieba.posseg模块中的cut函数来对文本进行分词和词性标注。
    • 然后使用一个循环遍历词性标注结果,只保留名词、动词、形容词。
    • 同时还去掉了长度为1的字符,并使用停用词表进行了停用词处理。
    • 最后将经过处理的单词保存在了filtered_words列表中,并使用print函数将其输出。
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月17日
  • 已采纳回答 1月9日
  • 创建了问题 1月5日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。