Запись в текстовый файл в формате UTF-8 - Python - PullRequest
1 голос
/ 25 апреля 2020
Приложение

My django получает документ от пользователя, создает отчет о нем и записывает в файл txt. Интересная проблема заключается в том, что все работает очень хорошо на моей ОС Ma c. Но на Windows он не может читать некоторые буквы, преобразует его в символы вроде é™, ä±. Вот мои коды:

views.py:

def result(request):
    last_uploaded = OriginalDocument.objects.latest('id')
    original = open(str(last_uploaded.document), 'r')
    original_words = original.read().lower().split()
    words_count = len(original_words)
    open_original = open(str(last_uploaded.document), "r")
    read_original = open_original.read()
    characters_count = len(read_original)
    report_fives = open("static/report_documents/" + str(last_uploaded.student_name) + 
    "-" + str(last_uploaded.document_title) + "-5.txt", 'w', encoding="utf-8")
    # Path to the documents with which original doc is comparing
    path = 'static/other_documents/doc*.txt'
    files = glob.glob(path)
    #endregion

    rows, found_count, fives_count, rounded_percentage_five, percentage_for_chart_five, fives_for_report, founded_docs_for_report = search_by_five(last_uploaded, 5, original_words, report_fives, files)


    context = {
        ...
    }

    return render(request, 'result.html', context)

report txt file:

['universitetindé™', 'té™hsili', 'alä±ram.', 'mé™n'] was found in static/other_documents\doc1.txt.
...

1 Ответ

1 голос
/ 25 апреля 2020

Проблема в том, что вы вызываете open() для файла без указания кодировки. Как отмечено в документации Python , кодировка по умолчанию зависит от платформы. Вероятно, поэтому вы видите разные результаты в Windows и MacOS.

Предполагая, что сам файл действительно был закодирован в UTF-8, просто укажите это при чтении файла:

original = open(str(last_uploaded.document), 'r', encoding="utf-8")
...