improve character encoding detection

This commit is contained in:
josdion 2020-03-26 20:10:58 +02:00
parent 92497a8822
commit be0411d50a

View file

@ -379,10 +379,12 @@ def guess_external_subtitles(dest_folder, subtitles):
try: try:
# to improve performance, use only the first 32K to detect encoding # to improve performance, use only the first 32K to detect encoding
if len(text) > 32768: guess = chardet.detect(text[:32768]) guess = chardet.detect(text[:32768])
else: guess = chardet.detect(text) logging.debug('BAZARR detected encoding %r', guess)
if guess["confidence"] < 0.8: if guess["confidence"] < 0.6:
raise UnicodeError raise UnicodeError
if guess["confidence"] < 0.8 or guess["encoding"] == "ascii":
guess["encoding"] = "utf-8"
text = text.decode(guess["encoding"]) text = text.decode(guess["encoding"])
detected_language = guess_language(text) detected_language = guess_language(text)
except UnicodeError: except UnicodeError: