繁体   English   中英

Python 3中str.translate的自定义表

[英]Custom table for str.translate in Python 3

如果我运行此代码:

s.translate(str.maketrans({'as': 'dfg', '1234': 'qw'}))

我会得到:

ValueError: string keys in translate table must be of length 1

有没有办法使用str.translate一次替换多个字符? Docs说我可以使用codecs来实现灵活的方法,但是我不知道怎么做。

如果没有,那该怎么办呢?

不行 str.translate可以单独使用,以取代单独的字符。 替换字符串可以是任何长度,但是必须是单个字符。


当他们的文档中提到codecs他们是说您可以实现自定义编码,进行注册,然后使用该文件打开文件...调用诸如codecs.maketrans之类的东西并不是一件codecs.maketrans ,这是很多工作。 我个人将re.sub与功能替换一起使用:

replacements = {'as': 'dfg', '1234': 'qw'}
re.sub('({})'.format('|'.join(map(re.escape, replacements.keys()))), lambda m: replacements[m.group()], text)

哪个似乎可以满足您的要求:

>>> re.sub('({})'.format('|'.join(map(re.escape, replacements.keys()))), lambda m: replacements[m.group()], "test as other test1234")
'test dfg other testqw'

字符串的translate方法根据您提供的翻译用字符串替换一个字符。

以下是几种情况:

Original string: as 1234
Error in [s.translate(str.maketrans({'as': 'dfg', '1234': 'qw'}))]
Error in [s = s.translate(str.maketrans({'a': 'd', '12': 'q'}))]
s.translate(str.maketrans({'a': 'd', '1': 'q'})): ds q234

解决方案以获得结果

编辑问题之后,以下是获得所需替换的解决方案:

按键拆分,然后按翻译词典中的值加入。

Replaced all subsrings: dfg qw

编码:

s = 'as 1234'
print('Original string:',s)
try:
    w = s.translate(str.maketrans({'as': 'dfg', '1234': 'qw'}))
    print("s.translate(str.maketrans({'as': 'dfg', '1234': 'qw'}):", w)
except:
    print("Error in [s.translate(str.maketrans({'as': 'dfg', '1234': 'qw'}))]")
try:   
    w = s.translate(str.maketrans({'a': 'd', '12': 'q'}))
    print("s.translate(str.maketrans({'a': 'd', '12': 'q'})):", w)
except:
    print("Error in [s = s.translate(str.maketrans({'a': 'd', '12': 'q'}))]")
try:   
    w = s.translate(str.maketrans({'a': 'd', '1': 'q'}))
    print("s.translate(str.maketrans({'a': 'd', '1': 'q'})):", w)
except:
    print("Error in [s = s.translate(str.maketrans({'a': 'd', '1': 'q'}))]")

trans_dict = {'as': 'dfg', '1234': 'qw'}
for k,v in trans_dict.items():
    y = s.split(k)
    s = v.join(y)
print('Replaced all subsrings:',s)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM