游雁
2023-11-20 df03a020f6d8fe4e9b09c1e784fead2852d90bfc
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
30
31
32
33
34
#!/usr/bin/env python3
# encoding: utf-8
 
import sys
 
# sys.argv[1]: lm dict
# sys.argv[2]: lexicon file
# sys.argv[3]: lexicon file for corpus.dict
 
lex_dict = {}
with open(sys.argv[2], 'r', encoding='utf8') as fin:
    for line in fin:
        words = line.strip().split('\t')
        if len(words) != 2:
            continue
        lex_dict[words[0]] = words[1]
 
with open(sys.argv[1], 'r', encoding='utf8') as fin, \
        open(sys.argv[3], 'w', encoding='utf8') as fout:
    for line in fin:
        word = line.strip()
        if word == '<s>' or word == '</s>':
            continue
        word_lex = ""
        if word in lex_dict:
            word_lex = lex_dict[word]
        else:
            for i in range(len(word)):
                if word[i] in lex_dict:
                    word_lex += " " + lex_dict[word[i]]
                else:
                    word_lex += " <unk>" 
            
        fout.write('{}\t{}\n'.format(word, word_lex.strip()))