我的代码在python 2.x版本上运行正常但是当我试图在python 3.x版本上运行它时,它给出了错误。
主题:需要缩写sms编码中的任何消息。
代码:
def sms_encoding(data):
#start writing your code here
print(data)
data.split(" ")
data_list=data.split(" ")
sms_encd=[]
final_sms=""
for i in range(len(data_list)):
if data_list[i].lower() in ['a','e','i','o','u']:
sms_encd.append(data_list[i])
elif len(data_list[i])>1:
a = data_list[i].translate(None,'aeiouAEIOU')
sms_encd.append(a)
for j in range(len(sms_encd)):
final_sms += str(sms_encd[j])+" "
return final_sms[:-1]
data="I will not repeat mistakes"
print(sms_encoding(data))
输出:
2.x版本:
I will not repeat mistakes
I wll nt rpt mstks
3.x版本:
I will not repeat mistakes
Traceback (most recent call last):
File "python", line 18, in <module>
File "python", line 12, in sms_encoding
TypeError: translate() takes exactly one argument (2 given)
为什么translate()
无效?还有其他替代方法吗?
答案 0 :(得分:6)
您需要将Python 3&#39; str.translate()
与Python 2 unicode.translate()
进行比较。两者都将映射从代码点(整数)转换为替换(另一个整数或单字符Unicode e字符串)。
str
类型有一个静态方法str.maketrans()
,它将字符到删除(Python 2的第二个参数&#39; s str.translate()
)作为第三个参数,制作这样的地图。在这里使用:
map = str.maketrans('', '', 'aeiouAEIOU')
a = data_list[i].translate(map)
这会输出一个字典,将每个元音代码点映射到None
:
>>> str.maketrans('', '', 'aeiouAEIOU')
{97: None, 101: None, 105: None, 111: None, 117: None, 65: None, 69: None, 73: None, 79: None, 85: None}