如何正确设置 fst 规则



我与转换器和python取得了联系,所以我使用默认的FST库。 例如,我有一个列表['a','b','c']. 如果后面跟着'c',我需要替换'b'. 我制定了以下规则,但仅当'b''a''c' 之间并且仅使用此长度的数组时,它才有效。

from fst import fst
list = ['a','b','c']
t = fst.FST('example')
for i in range(0,len(list)):
    t.add_state(str(i))
t.initial_state = '0'
t.add_arc('0','0',('a'),('a'))
t.add_arc('0','1',('b'),('d'))
t.add_arc('1','1',('c'),('c'))
t.set_final('1')
print t.transduce(list)

我得到了['a','d','c']我需要能够用'd'替换'b',无论它在哪里。例如,在后跟'l'时替换'b'

['m','r','b','l'] => ['m','r','o','l'] 
['m','b','l'] => ['m','o','l'] 
['b','l','o'] => ['o','l','o'] 

请帮助我,谢谢!

考虑这个函数...

lists = [['m','r','b','l'], 
         ['m','b','l'], 
         ['b','l','o'], 
         ['b','m','o']]
def change(list_, find_this, followed_by, replace_to):
    return_list = list_.copy()
    idx = list_.index(find_this)
    if list_[idx+1] == followed_by:
        return_list = list_.copy()
        return_list[idx] = replace_to
    return return_list
for lst in lists:
    print(change(lst, 'b', 'l', 'o'))
''' output:
['m', 'r', 'o', 'l']
['m', 'o', 'l']
['o', 'l', 'o']
['b', 'm', 'o']
'''

不过,您应该添加其他相关的验证。

相关内容

  • 没有找到相关文章

最新更新