我有一个问题要理解这个python代码的问题:
import chardet
from mutagen.mp3 import MP3
id3 = MP3("./test.mp3")
artist_name_byte = bytes(id3['TPE1'])
print( artist_name_byte)
encoding = chardet.detect(artist_name_byte)
print(encoding['encoding'])
artist_name_string = artist_name_byte.decode('utf-8')
print(artist_name_string)产出如下:
b'H\xc3\xa9l\xc3\xa8ne Grimaud'
utf-8
[Decode error - output not utf-8]为什么会有解码错误?
发布于 2014-03-16 10:12:31
您在这里没有解码错误:
>>> b'H\xc3\xa9l\xc3\xa8ne Grimaud'.decode('utf8')
'Hélène Grimaud'很可能会有一个异常打印unicode字符串。您没有显示回溯,但是您需要注意抛出它的行和异常的确切名称。
例如,print()行将是跟踪中的最后一行,而不是.decode()行,例外将是UnicodeEncodeError,而不是UnicodeDecodeError。
确保您的控制台、终端或IDE设置正确,并能处理拉丁文-1码点.例如,如果Python告诉您'ascii' codec can't encode character ...,那么控制台很可能不会告诉Python什么是可接受的编解码器。
https://stackoverflow.com/questions/22435438
复制相似问题