zoukankan      html  css  js  c++  java
  • 吴裕雄--天生自然 pythonTensorFlow自然语言处理:文本数据预处理--生成训练文件

    import sys
    import codecs
    
    # 1. 参数设置
    MODE = "PTB_TRAIN"    # 将MODE设置为"PTB_TRAIN", "PTB_VALID", "PTB_TEST", "TRANSLATE_EN", "TRANSLATE_ZH"之一。
    
    if MODE == "PTB_TRAIN":        # PTB训练数据
        RAW_DATA = "F:\TensorFlowGoogle\201806-github\datasets\PTB_data\ptb.train.txt"  # 训练集数据文件
        VOCAB = "F:\temp\ptb.vocab"                                 # 词汇表文件
        OUTPUT_DATA = "F:\temp\ptb.train"                           # 将单词替换为单词编号后的输出文件
    elif MODE == "PTB_VALID":      # PTB验证数据
        RAW_DATA = "F:\TensorFlowGoogle\201806-github\datasets\PTB_data\ptb.valid.txt"
        VOCAB = "F:\temp\ptb.vocab"
        OUTPUT_DATA = "F:\temp\ptb.valid"
    elif MODE == "PTB_TEST":       # PTB测试数据
        RAW_DATA = "F:\TensorFlowGoogle\201806-github\datasets\PTB_data\ptb.test.txt"
        VOCAB = "F:\temp\ptb.vocab"
        OUTPUT_DATA = "F:\temp\ptb.test"
    elif MODE == "TRANSLATE_ZH":   # 中文翻译数据
        RAW_DATA = "F:\TensorFlowGoogle\201806-github\datasets\TED_data\train.txt.zh"
        VOCAB = "F:\temp\zh.vocab"
        OUTPUT_DATA = "F:\temp\train.zh"
    elif MODE == "TRANSLATE_EN":   # 英文翻译数据
        RAW_DATA = "F:\TensorFlowGoogle\201806-github\datasetsTED_data\train.txt.en"
        VOCAB = "F:\temp\en.vocab"
        OUTPUT_DATA = "F:\temp\train.en"
    # 2.按词汇表对将单词映射到编号。
    # 读取词汇表,并建立词汇到单词编号的映射。
    with codecs.open(VOCAB, "r", "utf-8") as f_vocab:
        vocab = [w.strip() for w in f_vocab.readlines()]
        
    word_to_id = {k: v for (k, v) in zip(vocab, range(len(vocab)))}
    
    # 如果出现了不在词汇表内的低频词,则替换为"unk"。
    def get_id(word):
        return word_to_id[word] if word in word_to_id else word_to_id["<unk>"]
    # 3.对数据进行替换并保存结果。
    fin = codecs.open(RAW_DATA, "r", "utf-8")
    fout = codecs.open(OUTPUT_DATA, 'w', 'utf-8')
    for line in fin:
        words = line.strip().split() + ["<eos>"]  # 读取单词并添加<eos>结束符
        # 将每个单词替换为词汇表中的编号
        out_line = ' '.join([str(get_id(w)) for w in words]) + '
    '
        fout.write(out_line)
    fin.close()
    fout.close()
  • 相关阅读:
    P1144 最短路计数
    P2966 [USACO09DEC]牛收费路径Cow Toll Paths
    P2419 [USACO08JAN]牛大赛Cow Contest
    P1462 通往奥格瑞玛的道路
    P1346 电车
    P1339 [USACO09OCT]热浪Heat Wave
    P1418 选点问题
    P1330 封锁阳光大学
    P1182 数列分段Section II
    P2661 信息传递
  • 原文地址:https://www.cnblogs.com/tszr/p/12068418.html
Copyright © 2011-2022 走看看