1

假设我有一个这样的字符串列表:

['001+11', '010+10', '011+01', '100+11']

我想得到这个:

['0*0*1+1*1', '0*1*0+1*0', '0*1*1+0*1', '1*0*0+1*1']

我知道这里的条件是,只要有 0 或 1,我们必须用数字+“*”替换数字,但当数字的下一个元素是“+”时不要这样做。所以我写了一个 python 代码如下-

binary=["0","1"]
for string in out:#out is the list of strings
    for i in range(len(string)):
        if string[i] in binary:
            out[out.index(string)]=change(string,string[i],string[i]+"*")
            break
print out

这使输出为-

['0*01+01', '0*00+01', '0*11+00', '0*10+00', '1*01+11', '1*00+11', '1*11+10', '1*10+10']

所以,我意识到如果我再运行一个“while循环”,我会得到我想要的(一个while循环,因为我们必须提到“for循环”中的循环重复次数,这里不是一个选择)。但是我无法弄清楚while的条件应该是什么。很多这一切听起来有点复杂,所以我想,也许还有其他方法可以实现我想要的东西。因此,问题。

注意——这是一个更大的程序的一部分,用于从任何不是用 Python 格式编写的布尔表达式中获取真值表。如果这部分得到解决,其余的可能可以使用 eval 来解决。提前致谢!

EDIT1--change 是一个用户定义的函数,它改变一个更大字符串的子字符串。

def change(string,old,new):
    pos=string.index(old)
    return string[:pos]+new+string[pos+1:]
4

3 回答 3

5

这是一个使用列表理解的单行代码,joinsplit完成工作:

>>> lst = ['001+11', '010+10', '011+01', '100+11']
>>> [ '+'.join('*'.join(x) for x in s.split('+')) for s in lst ]
['0*0*1+1*1', '0*1*0+1*0', '0*1*1+0*1', '1*0*0+1*1']
于 2019-12-22T12:18:53.333 回答
2

我喜欢 kaya3 的解决方案,但这是另一个使用正则表达式的解决方案:

>>> import re
>>> [re.sub(r'(\d)(?=\d)', r'\1*', s) for s in out]
['0*0*1+1*1', '0*1*0+1*0', '0*1*1+0*1', '1*0*0+1*1']
于 2019-12-22T12:40:14.580 回答
2
re.sub('\B', '*', s)

演示:

>>> lst = ['001+11', '010+10', '011+01', '100+11']
>>> [re.sub('\B', '*', s) for s in lst]
['0*0*1+1*1', '0*1*0+1*0', '0*1*1+0*1', '1*0*0+1*1']
于 2019-12-25T05:29:39.087 回答