Напишите программу, которая читает текст из файла и отображает на экране только предложения
Обновлено: 21.11.2024
Функция Python print() обычно используется для отображения текста либо в командной строке, либо в интерактивном интерпретаторе, в зависимости от того, как выполняется программа Python. Однако мы можем изменить его поведение, чтобы он записывал текст в файл, а не в консоль.
В этой статье мы рассмотрим множество способов записи в файл с помощью функции print().
Перенаправление вывода скрипта Python в терминал
Быстрый и грязный способ перенаправить вывод скрипта Python напрямую из командной строки во время выполнения скрипта.
Например, если бы у нас был файл Python с именем hello.py со следующим содержимым:
Мы можем перенаправить вывод файла в оболочке, используя одну правую угловую скобку:
Если мы откроем только что созданный файл output.txt, мы увидим следующее содержимое:
Однако при использовании этого метода все выходные данные скрипта записываются в файл. Часто более гибко выполнять это перенаправление из самого скрипта Python.
Перенаправление стандартного потока вывода
В Python функция print() более гибкая, чем вы думаете. Он не был жестко запрограммирован таким образом, чтобы указанный текст мог быть записан только на дисплей. Вместо этого он отправляет текст в место, называемое стандартным потоком вывода, также известным как stdout .
Все системы UNIX имеют три основных канала: стандартный канал ввода ( stdin ), стандартный канал вывода ( stdout ) и стандартный канал ошибок ( стандартный вывод).
По умолчанию стандартный канал вывода указывает на интерактивное окно, используемое для выполнения программы, поэтому обычно мы видим текст, распечатываемый на экране. Однако для удобства стандартный вывод можно перенаправить в другие места, например в файлы.
Если стандартный вывод перенаправляется в определенный файл, текст, указанный в функции print(), будет записан в этот файл, а не отображаться на экране.
В Python ссылку на стандартный вывод можно получить с помощью объекта stdout модуля sys. Это файлоподобный объект, то есть у него есть методы, которые позволяют Python читать и писать из него, как из реального файла.
Давайте рассмотрим пример, в котором мы меняем стандартный вывод на файл:
Функция print() принимает предоставленный строковый аргумент, добавляет в конец символ новой строки и вызывает метод stdout.write(), чтобы записать его в стандартный вывод.
В приведенном выше примере мы сначала печатаем строку текста, как мы привыкли, которая будет отображаться в консоли при запуске файла. Затем мы переназначили stdout нашему пользовательскому файловому объекту — f. Так как файловый объект имеет вполне допустимый метод write(), наше напечатанное значение будет записано в файл без проблем.
Обратите внимание, что рекомендуется сохранять исходное значение стандартного вывода в переменной перед его изменением. Таким образом, мы можем восстановить исходное значение стандартного вывода после того, как закончим, что поможет избежать путаницы.
Давайте сохраним код в новый файл, printToFile.py . А затем давайте выполним его:
Мы увидим следующий вывод в Терминале:
И скрипт создаст новый файл с именем filename.txt со следующим содержимым:
Вы успешно перенаправили данные из стандартного потока вывода в файл. Давайте посмотрим, как мы можем сделать это с другим популярным файловым объектом, предназначенным для ошибок программирования.
Перенаправление стандартного потока ошибок
Бесплатная электронная книга: Git Essentials
Ознакомьтесь с нашим практическим руководством по изучению Git, включающим передовые практики, общепринятые стандарты и памятку. Перестаньте гуглить команды Git и на самом деле изучите их!
В Python ошибки записываются в стандартный поток ошибок, также известный как stderr . По умолчанию это также интерактивное окно, но его можно изменить с помощью объекта sys.stderr. Если бы мы хотели напечатать значения в stderr , мы могли бы просто перенаправить sys.stdout так, чтобы он указывал на sys.stderr .
Создайте файл с именем printToStderr.py и добавьте следующий код:
Этот пример почти идентичен предыдущему, за исключением того, что вместо перенаправления стандартного потока вывода в файл мы перенаправляем его в стандартный поток ошибок. Если бы стандартный поток ошибок также был перенаправлен куда-то еще, выходные данные были бы отправлены в это место, а не на экран.
Давайте запустим этот файл:
Наши выходные данные будут выглядеть так:
Хотя для нас это может выглядеть как обычный вывод, для компьютера он отображается через другие конвейеры.
Печать с использованием параметра "файл"
В предыдущих примерах мы явно перенаправляли стандартный вывод на другой файлоподобный объект, изменяя объект stdout.Однако для удобства мы можем сделать это непосредственно из функции print(), указав место вывода с помощью параметра файла:
Например, если бы мы хотели печатать напрямую в файл, не изменяя весь стандартный вывод скрипта, мы бы написали:
Поскольку мы не возились с явным перенаправлением стандартного вывода, нам больше не нужно сбрасывать его до исходного значения. В результате это предпочтительный способ записи в файл с помощью функции print().
Примечание. Несмотря на то, что имя параметра — файл , помните, что он работает с любым файлоподобным объектом. Например, если вы хотите напечатать в stderr , вы должны изменить оператор print() на:
Заключение
В этой статье мы обсудили перенаправление вывода функции print() Python с помощью различных методов. Эти методы включали перенаправление вывода скрипта Python из командной строки, перенаправление стандартного вывода в скриптах Python и указание файлового объекта в параметре файла непосредственно в функции print().
Об авторе
Эта статья была написана Джейкобом Стопаком, разработчиком программного обеспечения и консультантом, стремящимся помочь другим улучшить свою жизнь с помощью кода. Джейкоб является автором Руководства по основам кодирования для разработчиков, вводной книги, в которой рассматриваются основные концепции и инструменты кодирования. Он содержит главы об основах компьютерной архитектуры, Интернете, командной строке, HTML, CSS, JavaScript, Python, Java, базах данных/SQL, Git и многом другом.
Распространенной задачей в программировании является открытие файла и анализ его содержимого. Что вы делаете, когда файл, который вы пытаетесь обработать, довольно большой, например, несколько ГБ данных или больше? Решение этой проблемы состоит в том, чтобы читать фрагменты файла за раз, обрабатывать его, а затем освобождать его из памяти, чтобы вы могли обрабатывать другой фрагмент, пока не будет обработан весь массивный файл. Хотя вы сами определяете подходящий размер фрагментов данных, которые вы обрабатываете, для многих приложений удобно обрабатывать файл по одной строке за раз.
В этой статье мы рассмотрим ряд примеров кода, демонстрирующих, как читать файлы построчно. Если вы хотите попробовать некоторые из этих примеров самостоятельно, код, использованный в этой статье, можно найти в следующем репозитории GitHub.
Базовый файловый ввод-вывод в Python
Python — это отличный язык программирования общего назначения, и в его стандартной библиотеке встроенных функций и модулей есть ряд очень полезных функций файлового ввода-вывода.
Встроенная функция open() используется для открытия файлового объекта для чтения или записи. Вот как вы можете использовать его, чтобы открыть файл:
Как показано выше, функция open() принимает несколько аргументов. Мы сосредоточимся на двух аргументах, первый из которых представляет собой позиционный строковый параметр, представляющий путь к файлу, который вы хотите открыть. Второй (необязательный) параметр также является строкой и указывает режим взаимодействия, который вы собираетесь использовать с файловым объектом, возвращаемым вызовом функции. Наиболее распространенные режимы перечислены в таблице ниже, по умолчанию для чтения используется 'r':
Режим | Описание |
---|---|
r | Открыть для чтения обычного текста |
w | Открыть для записи обычного текста |
a | Открыть существующий файл для добавления простого текста |
rb | Открыть для чтения двоичных данных |
wb | Открыть для записи двоичных данных |
После того как вы записали или прочитали все нужные данные в файловом объекте, вам нужно закрыть файл, чтобы можно было перераспределить ресурсы в операционной системе, в которой выполняется код.
Примечание. Всегда рекомендуется закрывать ресурс файлового объекта, но об этой задаче легко забыть.
Хотя вы всегда можете помнить о вызове close() для файлового объекта, существует альтернативный и более элегантный способ открыть файловый объект и убедиться, что интерпретатор Python выполняет очистку после его использования:
Просто используя ключевое слово with (появившееся в Python 2.5) в коде, который мы используем для открытия файлового объекта, Python сделает что-то похожее на следующий код. Это гарантирует, что независимо от того, какой файловый объект будет закрыт после использования:
Подходит любой из этих двух методов, при этом первый пример более Pythonic.
Объект файла, возвращаемый функцией open(), имеет три общих явных метода (read(), readline() и readlines()) для чтения данных. Метод read() считывает все данные в одну строку. Это полезно для небольших файлов, где вы хотели бы выполнять манипуляции с текстом во всем файле.Затем есть readline() , который является полезным способом чтения только отдельных строк, постепенно увеличивая количество за раз, и возвращать их в виде строк. Последний явный метод readlines() прочитает все строки файла и вернет их в виде списка строк.
Построчное чтение файла в Python с помощью readline()
Начнем с метода readline(), который считывает одну строку, что потребует от нас использования счетчика и его увеличения:
Этот фрагмент кода открывает файловый объект, ссылка на который хранится в fp , а затем считывает строки по одной, итеративно вызывая readline() для этого файлового объекта в цикле while. Затем он просто выводит строку на консоль.
Запустив этот код, вы должны увидеть примерно следующее:
Однако этот подход грубый и явный. Наверняка не очень Pythonic. Мы можем использовать метод readlines(), чтобы сделать этот код более кратким.
Построчное чтение файла с помощью readlines()
Метод readlines() считывает все строки и сохраняет их в List . Затем мы можем перебрать этот список и с помощью enumerate() создать индекс для каждой строки для нашего удобства:
В результате:
Бесплатная электронная книга: Git Essentials
Ознакомьтесь с нашим практическим руководством по изучению Git, включающим передовые практики, общепринятые стандарты и памятку. Перестаньте гуглить команды Git и на самом деле изучите их!
Теперь, хотя и намного лучше, нам даже не нужно вызывать метод readlines() для достижения этой той же функциональности. Это традиционный способ чтения файла построчно, но есть и более современный и более короткий способ.
Чтение файла построчно с помощью цикла for – наиболее подход Pythonic
Возвращенный файл сам по себе является итерируемым. Нам вообще не нужно извлекать строки через readlines() — мы можем перебрать сам возвращаемый объект. Это также упрощает его перечисление(), чтобы мы могли писать номер строки в каждом операторе print().
Это самый короткий, самый питоновский подход к решению проблемы, и этот подход нравится большинству:
В результате:
Здесь мы воспользуемся преимуществами встроенных функций Python, которые позволяют нам легко выполнять итерацию по итерируемому объекту, просто используя цикл for. Если вы хотите узнать больше о встроенных функциях Python для итерации объектов, мы предоставим вам информацию:
Применения построчного чтения файлов
Как это можно использовать на практике? Большинство приложений НЛП имеют дело с большими объемами данных. В большинстве случаев нецелесообразно считывать весь корпус в память. Хотя это и рудиментарно, вы можете написать решение с нуля для подсчета частоты определенных слов без использования каких-либо внешних библиотек. Давайте напишем простой скрипт, который загружает файл, читает его построчно и подсчитывает частоту слов, печатая 10 наиболее часто встречающихся слов и количество их вхождений:
Сценарий использует модуль os, чтобы убедиться, что файл, который мы пытаемся прочитать, действительно существует. Если да, то он читается построчно, и каждая строка передается в функцию record_word_cnt(). Он разграничивает пробелы между словами и добавляет слово в словарь — bag_of_words. Как только все строки записаны в словарь, мы упорядочиваем их с помощью функции order_bag_of_words(), которая возвращает список кортежей в формате (word, word_count), отсортированных по количеству слов.
Наконец, мы печатаем десять самых распространенных слов.
Обычно для этого создается модель Bag of Words с использованием таких библиотек, как NLTK, однако этой реализации будет достаточно. Запустим скрипт и предоставим ему наш Iliad.txt:
В результате:
Если вы хотите узнать больше о НЛП, у нас есть серия руководств по различным задачам: Обработка естественного языка в Python.
Заключение
В этой статье мы рассмотрели несколько способов построчного чтения файла в Python, а также создали элементарную модель Bag of Words для расчета частотности слов в файле. данный файл.
Привет! Если вы хотите научиться работать с файлами в Python, то эта статья для вас. Работа с файлами — важный навык, который должен освоить каждый разработчик Python, так что давайте начнем.
Из этой статьи вы узнаете:
- Как открыть файл.
- Как прочитать файл.
- Как создать файл.
- Как изменить файл.
- Как закрыть файл.
- Как открывать файлы для нескольких операций.
- Как работать с методами файлового объекта.
- Как удалить файлы.
- Как работать с контекстными менеджерами и чем они полезны.
- Как обрабатывать исключения, которые могут возникнуть при работе с файлами.
- и многое другое!
Начнем! ✨
🔹 Работа с файлами: базовый синтаксис
Одной из наиболее важных функций, которые вам понадобятся при работе с файлами в Python, является open() , встроенная функция, которая открывает файл и позволяет вашей программе использовать его и работать с ним. р>
Это основной синтаксис:
💡 Совет. Это два наиболее часто используемых аргумента для вызова этой функции. Есть шесть дополнительных необязательных аргументов. Чтобы узнать о них больше, прочитайте эту статью в документации.
Первый параметр: файл
Первым параметром функции open() является файл, абсолютный или относительный путь к файлу, с которым вы пытаетесь работать.
Обычно мы используем относительный путь, который указывает, где находится файл относительно расположения скрипта (файла Python), вызывающего функцию open().
Например, путь в этом вызове функции:
Содержит только имя файла. Это можно использовать, когда файл, который вы пытаетесь открыть, находится в том же каталоге или папке, что и скрипт Python, например:
Но если файл находится во вложенной папке, например:
Файл names.txt находится в папке "data"
Затем нам нужно использовать определенный путь, чтобы сообщить функции, что файл находится в другой папке.
В этом примере это будет путь:
Обратите внимание, что мы сначала пишем data/ (имя папки, за которым следует символ / ), а затем name.txt (имя файла с расширением).
💡 Совет. Три буквы .txt, следующие за точкой в файле name.txt, — это «расширение» файла или его тип. В этом случае .txt указывает, что это текстовый файл.
Второй параметр: режим
Второй параметр функции open() — это режим, строка из одного символа. Этот единственный символ в основном сообщает Python, что вы планируете делать с файлом в своей программе.
- Читать ("r").
- Добавить ("a")
- Напишите ("w")
- Создать ( "x" )
Вы также можете открыть файл в:
Чтобы использовать текстовый или двоичный режим, вам необходимо добавить эти символы в основной режим. Например: "wb" означает запись в двоичном режиме.
💡 Совет: Режимы по умолчанию: чтение ("r") и текст ("t"), что означает "открыть для чтения текста" ("rt"), поэтому указывать их в open( ), если вы хотите их использовать, потому что они назначаются по умолчанию. Вы можете просто написать open() .
Почему режимы?
Для Python действительно имеет смысл предоставлять только определенные разрешения в зависимости от того, что вы планируете делать с файлом, верно? Почему Python должен позволять вашей программе делать больше, чем необходимо? Именно поэтому существуют режимы.
Подумайте об этом — позволить программе делать больше, чем необходимо, может быть проблематично. Например, если вам нужно только прочитать содержимое файла, может быть опасно позволять вашей программе неожиданно изменять его, что потенциально может привести к ошибкам.
🔸 Как прочитать файл
Теперь, когда вы больше знаете об аргументах, которые принимает функция open(), давайте посмотрим, как можно открыть файл и сохранить его в переменной для использования в программе.
Это основной синтаксис:
Мы просто присваиваем возвращаемое значение переменной. Например:
Я знаю, что вы можете спросить: какой тип значения возвращает open()?
Ну, файловый объект.
Давайте немного поговорим о них.
Файловые объекты
Согласно документации Python файловый объект это:
Объект, предоставляющий ориентированный на файл API (с такими методами, как read() или write()) базовому ресурсу.
По сути, это говорит нам о том, что файловый объект — это объект, который позволяет нам работать и взаимодействовать с существующими файлами в нашей программе Python.
Файловые объекты имеют такие атрибуты, как:
Теперь давайте посмотрим, как можно получить доступ к содержимому файла через файловый объект.
Способы чтения файла
Чтобы мы могли работать с файловыми объектами, нам нужен способ "взаимодействовать" с ними в нашей программе, и это именно то, что делают методы. Давайте посмотрим на некоторые из них.
Прочитать()
Первый метод, о котором вам нужно узнать, это read() , который возвращает все содержимое файла в виде строки.
Вот пример:
Вы можете использовать функцию type(), чтобы убедиться, что значение, возвращаемое функцией f.read(), является строкой:
Да, это строка!
В данном случае был напечатан весь файл, потому что мы не указали максимальное количество байтов, но мы можем сделать и это.
Вот пример:
Возвращаемое значение ограничено этим количеством байтов:
❗️Важно: файл необходимо закрыть после завершения задачи, чтобы освободить ресурсы, связанные с файлом. Для этого вам нужно вызвать метод close(), например:
Readline() и Readlines()
Вы можете прочитать файл построчно с помощью этих двух методов. Они немного отличаются, поэтому давайте рассмотрим их подробнее.
readline() читает одну строку файла, пока не достигнет конца этой строки. Завершающий символ новой строки ( \n ) сохраняется в строке.
💡 Совет. При желании вы можете указать размер, максимальное количество символов, которое вы хотите включить в результирующую строку.
Это первая строка файла.
Напротив, readlines() возвращает список со всеми строками файла в виде отдельных элементов (строк). Это синтаксис:
Обратите внимание, что в конце каждой строки, кроме последней, есть символ \n (символ новой строки).
💡 Совет. Тот же список можно получить с помощью list(f) .
Вы можете работать с этим списком в своей программе, назначив его переменной или используя его в цикле:
Мы также можем перебирать f напрямую (файловый объект) в цикле:
Это основные методы, используемые для чтения файловых объектов. Теперь давайте посмотрим, как вы можете создавать файлы.
🔹 Как создать файл
Если вам нужно создать файл "динамически" с помощью Python, вы можете сделать это в режиме "x".
Посмотрим, как. Это основной синтаксис:
Вот пример. Это мой текущий рабочий каталог:
Если я запускаю эту строку кода:
Создается новый файл с таким именем:
В этом режиме вы можете создать файл, а затем динамически писать в него, используя методы, которые вы изучите за несколько минут.
💡 Совет. Изначально файл будет пустым, пока вы его не измените.
Любопытно, что если вы попытаетесь запустить эту строку еще раз, а файл с таким именем уже существует, вы увидите такую ошибку:
Согласно документации Python, это исключение (ошибка выполнения):
Теперь, когда вы знаете, как создать файл, давайте посмотрим, как вы можете его изменить.
🔸 Как изменить файл
Чтобы изменить (записать) файл, вам нужно использовать метод write(). У вас есть два способа сделать это (добавить или написать) в зависимости от режима, который вы выбрали для его открытия. Давайте рассмотрим их подробно.
Добавить
"Добавление" означает добавление чего-либо в конец другого элемента. Режим "a" позволяет вам открыть файл, чтобы добавить к нему некоторое содержимое.
Например, если у нас есть этот файл:
И мы хотим добавить к нему новую строку, мы можем открыть ее, используя режим "a" (добавить), а затем вызвать метод write(), передав содержимое, которое мы хотим добавить, в качестве аргумента. р>
Это основной синтаксис для вызова метода write():
Вот пример:
💡 Совет: обратите внимание, что я добавляю \n перед строкой, чтобы указать, что я хочу, чтобы новая строка отображалась как отдельная строка, а не как продолжение существующей строки.
Это файл сейчас, после запуска скрипта:
💡 Совет: новая строка может не отображаться в файле, пока не запустится функция f.close().
Написать
Иногда может потребоваться удалить содержимое файла и полностью заменить его новым содержимым. Вы можете сделать это с помощью метода write(), если вы открываете файл в режиме "w".
Здесь у нас есть этот текстовый файл:
Если я запускаю этот скрипт:
Вот результат:
Как видите, открытие файла в режиме "w" и последующая запись в него заменяет существующее содержимое.
💡 Совет. Метод write() возвращает количество написанных символов.
Если вы хотите написать несколько строк одновременно, вы можете использовать метод writelines(), который принимает список строк. Каждая строка представляет собой строку, которую нужно добавить в файл.
Вот пример. Это исходный файл:
Если мы запустим этот скрипт:
Строки добавляются в конец файла:
Открыть файл для нескольких операций
Теперь вы знаете, как создавать, читать и записывать в файл, но что, если вы хотите сделать несколько вещей в одной программе? Давайте посмотрим, что произойдет, если мы попытаемся сделать это с помощью режимов, которые вы уже изучили:
Если вы открываете файл в режиме "r" (чтение), а затем пытаетесь в него записать:
Вы получите эту ошибку:
Аналогично, если вы открываете файл в режиме "w" (запись), а затем пытаетесь его прочитать:
Вы увидите эту ошибку:
То же самое произойдет с режимом "a" (добавление).
Как мы можем это решить? Чтобы иметь возможность прочитать файл и выполнить другую операцию в той же программе, нужно добавить к режиму символ "+", вот так:
Очень полезно, правда? Это, вероятно, то, что вы будете использовать в своих программах, но обязательно включите только те режимы, которые вам нужны, чтобы избежать потенциальных ошибок.
Иногда файлы больше не нужны. Давайте посмотрим, как вы можете удалять файлы с помощью Python.
🔹 Как удалить файлы
Чтобы удалить файл с помощью Python, необходимо импортировать модуль os, который содержит функции, взаимодействующие с вашей операционной системой.
💡 Совет. Модуль – это файл Python со связанными переменными, функциями и классами.
В частности, вам понадобится функция remove(). Эта функция принимает путь к файлу в качестве аргумента и автоматически удаляет файл.
Давайте рассмотрим пример. Мы хотим удалить файл с именем sample_file.txt .
Для этого пишем такой код:
- Первая строка: import os называется "оператором импорта". Этот оператор записывается в начале вашего файла и дает вам доступ к функциям, определенным в модуле os.
- Вторая строка: os.remove("sample_file.txt") удаляет указанный файл.
💡 Совет: вы можете использовать абсолютный или относительный путь.
Теперь, когда вы знаете, как удалять файлы, давайте рассмотрим интересный инструмент. Менеджеры контекста!
🔸 Познакомьтесь с контекстными менеджерами
Контекстные менеджеры — это конструкции Python, которые значительно упростят вашу жизнь. Используя их, вам не нужно помнить о закрытии файла в конце вашей программы, и у вас есть доступ к файлу в той части программы, которую вы выберете.
Синтаксис
Это пример диспетчера контекста, используемого для работы с файлами:
💡 Совет. Тело контекстного менеджера должно быть с отступом, точно так же, как мы делаем отступы для циклов, функций и классов. Если код не имеет отступа, он не будет считаться частью менеджера контекста.
После завершения тела менеджера контекста файл закрывается автоматически.
Пример
Вот пример:
Этот менеджер контекста открывает файл names.txt для операций чтения/записи и назначает этот файловый объект переменной f .Эта переменная используется в теле диспетчера контекста для ссылки на файловый объект.
Пытаюсь снова прочитать
После завершения тела файл автоматически закрывается, поэтому его нельзя прочитать, не открыв снова. Но ждать! У нас есть строка, которая пытается прочитать его снова, прямо здесь, внизу:
Посмотрим, что произойдет:
Эта ошибка возникает, потому что мы пытаемся прочитать закрытый файл. Потрясающе, правда? Всю тяжелую работу за нас делает менеджер контекста, он удобочитаем и лаконичен.
🔹 Как обрабатывать исключения при работе с файлами
При работе с файлами могут возникать ошибки. Иногда у вас может не быть необходимых разрешений для изменения или доступа к файлу, или файл может даже не существовать.
Как программист, вы должны предвидеть эти обстоятельства и учитывать их в своей программе, чтобы избежать внезапных сбоев, которые определенно могут повлиять на работу пользователя.
Давайте рассмотрим некоторые наиболее распространенные исключения (ошибки времени выполнения), которые могут возникнуть при работе с файлами:
ФайлНеНайденОшибка
Согласно документации Python, это исключение:
Например, если файл, который вы пытаетесь открыть, не существует в вашем текущем рабочем каталоге:
Вы увидите эту ошибку:
Давайте разберем эту ошибку построчно:
", строка 8, в . Эта строка сообщает вам, что ошибка возникла, когда код в файле, расположенном в
💡 Совет: Python очень подробно описывает сообщения об ошибках, верно? Это огромное преимущество в процессе отладки.
Ошибка разрешения
Это еще одно распространенное исключение при работе с файлами. Согласно документации Python, это исключение:
Возникает при попытке запустить операцию без соответствующих прав доступа, например разрешений файловой системы.
Это исключение возникает, когда вы пытаетесь прочитать или изменить файл, у которого нет прав доступа. Если вы попытаетесь это сделать, то увидите следующую ошибку:
IsADirectoryError
Согласно документации Python, это исключение:
Это конкретное исключение возникает, когда вы пытаетесь открыть или работать с каталогом, а не с файлом, поэтому будьте очень осторожны с путем, который вы передаете в качестве аргумента.
Как обрабатывать исключения
Для обработки этих исключений можно использовать оператор try/except. С помощью этого оператора вы можете «указать» своей программе, что делать в случае чего-то непредвиденного.
Это основной синтаксис:
Здесь вы можете увидеть пример с FileNotFoundError:
Это в основном говорит:
- Попробуйте открыть файл named.txt .
- Если выдается ошибка FileNotFoundError, не происходит сбой! Просто напечатайте описательное заявление для пользователя.
💡 Совет: вы можете выбрать, как поступить в данной ситуации, написав соответствующий код в блоке исключений. Возможно, вы могли бы создать новый файл, если он еще не существует.
Чтобы автоматически закрыть файл после выполнения задачи (независимо от того, было ли возбуждено исключение в блоке try или нет), вы можете добавить блок finally.
Это пример:
Существует много способов настроить оператор try/except/finally, и вы даже можете добавить блок else для запуска блока кода, только если в блоке try не возникало никаких исключений.
💡 Совет. Чтобы узнать больше об обработке исключений в Python, вы можете прочитать мою статью «Как обрабатывать исключения в Python: подробное визуальное введение».
🔸 Резюме
- С помощью Python можно создавать, читать, записывать и удалять файлы.
- Файловые объекты имеют собственный набор методов, которые вы можете использовать для работы с ними в своей программе.
- Менеджеры контекста помогают работать с файлами и управлять ими, автоматически закрывая их после завершения задачи.
- Обработка исключений является ключевым элементом Python. Общие исключения при работе с файлами включают FileNotFoundError , PermissionError и IsADirectoryError . Их можно обработать с помощью try/except/else/finally.
Я очень надеюсь, что моя статья вам понравилась и оказалась полезной. Теперь вы можете работать с файлами в своих проектах Python. Посмотрите мои онлайн-курсы. Следи за мной на Твиттере. ⭐️
Диктор Windows – это средство чтения с экрана и преобразования текста в речь, позволяющее слышать текст и элементы экрана, читаемые вслух. Вот как использовать и настраивать эту функцию специальных возможностей.
Windows уже давно предлагает программу чтения с экрана и функцию преобразования текста в речь под названием Экранный диктор. Этот инструмент может читать вслух веб-страницы, текстовые документы и другие файлы, а также озвучивать каждое действие, которое вы выполняете в Windows. Экранный диктор специально разработан для слабовидящих, но им может пользоваться любой. Давайте посмотрим, как это работает в Windows 10.
Включить экранный диктор
Если вы хотите использовать экранный диктор, сначала необходимо включить эту функцию. Нажмите кнопку «Пуск» и откройте «Настройки» > «Специальные возможности» > «Экранный диктор», чтобы просмотреть панель «Экранный диктор». Включите кнопку экранного диктора, и может появиться сообщение, объясняющее, как была обновлена раскладка клавиатуры экранного диктора, чтобы она больше соответствовала вашему опыту работы с другими программами чтения с экрана.
Нажмите "ОК", чтобы отказаться от этого сообщения, и установите флажок "Больше не показывать", если вы не хотите видеть это сообщение при каждом запуске экранного диктора.
Как использовать экранный диктор
Теперь, если вы хотите использовать экранный диктор в качестве удобного средства чтения текста в речь, вы готовы к работе. Вам просто нужно включить эту функцию внутри веб-страницы, документа или файла. Наведите курсор на область текста, которую должен начать читать экранный диктор. Нажмите Caps Lock + R, и Экранный диктор начнет читать вам текст на странице. Остановите экранный диктор, нажав клавишу Ctrl.
Изменить настройки экранного диктора
Во-первых, давайте рассмотрим различные настройки экранного диктора, доступные при прокрутке экрана вниз.
- Откройте главную страницу экранного диктора. Откроется экран «Добро пожаловать в Экранный диктор», где вы сможете узнать, как использовать и настраивать инструмент, а также узнать о новых функциях.
- Просмотрите полное руководство по экранному диктору в Интернете. Откроется веб-страница с полной информацией об использовании экранного диктора, а также оглавлением и описанием новых функций.
Параметры запуска
- Разрешить запуск экранного диктора с помощью сочетания клавиш. Если этот флажок установлен, вы можете использовать сочетание клавиш клавиша Win+Ctrl+Enter для включения и выключения экранного диктора.
- Запуск экранного диктора после входа в систему от моего имени. Это запустит экранный диктор после того, как вы войдете в Windows с помощью своей учетной записи.
- Показывать главную страницу экранного диктора при запуске экранного диктора. Это автоматически открывает экран приветствия экранного диктора при запуске инструмента.
- Сверните Экранный диктор на главную страницу на панель задач. Это сворачивает экран «Добро пожаловать в экранный диктор» на панель задач.
Настроить голос диктора
Вы можете изменить голос диктора несколькими способами. На экране настроек экранного диктора используйте раскрывающееся меню, чтобы выбрать, какой голос вы хотите использовать для экранного диктора.
Вы также можете изменить скорость, высоту и громкость выбранного голоса с помощью ползунков на экране настроек. Для изменения этих элементов также можно использовать определенные нажатия клавиш.
В Windows можно добавить дополнительные голоса, в том числе для других языков, выбрав «Настройки» > «Время и язык» > «Язык». Нажмите ссылку «Добавить больше голосов», а на следующем экране нажмите кнопку «Добавить голоса». Выберите язык, который хотите добавить, и нажмите «Добавить».
Изменить то, что вы слышите
По умолчанию Экранный диктор произносит вслух любые кнопки, экраны или окна, на которые вы наводите или выбираете, а также любой текст на этих экранах. Если вы хотите изменить этот уровень, щелкните раскрывающееся меню рядом с «Изменить уровень детализации, который Экранный диктор предоставляет для текста и элементов управления». Например, чтобы слышать только текст, а не элементы управления, выберите параметр Только текст или Некоторые сведения о тексте.
Под раскрывающимся меню находятся дополнительные параметры, позволяющие проверить, будут ли Экранный диктор выделять форматированный текст, читать вслух по символам, использовать знаки препинания для определения пауз и произносить дополнительные сведения, такие как текст справки, на кнопках и других элементах управления. р>
Второе раскрывающееся меню в этом разделе позволяет установить уровень контекста, который Экранный диктор предоставляет кнопкам и другим элементам управления. Вы можете сначала попробовать самый высокий вариант «Полный контекст старых и новых элементов управления», а затем понизить уровень, если хотите услышать меньше контекста. Затем вы можете указать, когда экранный диктор будет предоставлять сведения о кнопках до или после их активации. Затем вы можете попробовать другие три варианта для этого раздела: услышать подсказки о том, как взаимодействовать с кнопками и другими элементами управления; Слушайте, как диктор объявит, почему действие не может быть выполнено; и слышать звуковые сигналы при выполнении действий.
В разделе "Изменение того, что вы слышите при вводе", вы можете указать, хотите ли вы слышать буквы, цифры, слова, функциональные клавиши, клавиши навигации, клавиши-переключатели и клавиши-модификаторы при их вводе.
Дополнительные настройки для изменения
В разделе "Выберите настройки клавиатуры" вы можете выбрать раскладку клавиатуры и выбрать измененную клавишу экранного диктора. Щелкните ссылку «Создание собственных команд клавиатуры», и вы сможете выбрать одну из множества команд для использования с Экранным диктором.
В разделе "Использование курсора экранного диктора" вы можете определить, как и где работает курсор экранного диктора и как вы можете управлять им с помощью мыши или клавиатуры. В разделе "Использование Брайля" вы можете установить и настроить программное обеспечение Брайля для использования дисплея Брайля с Windows.
В разделе "Синхронизировать мои настройки" нажмите кнопку "Использовать текущие настройки перед входом в систему", чтобы сохранить любые изменения, внесенные в настройки экранного диктора, чтобы они автоматически применялись ко всем, кто использует Windows на этом компьютере.
информационный бюллетень с советами экспертов по максимально эффективному использованию вашей технологии.","first_published_at":"2021-09-30T21:23:24.000000Z","published_at":"2021-09-30T21:23:24.000000Z ","last_published_at":"2021-09-30T21:23:13.000000Z","created_at":null,"updated_at":"2021-09-30T21:23:24.000000Z">)" x-show="showEmailSignUp ()">
Нравится то, что вы читаете?
Подпишитесь на информационный бюллетень с советами и рекомендациями, чтобы получить советы экспертов, чтобы максимально эффективно использовать свои технологии.
Этот информационный бюллетень может содержать рекламу, предложения или партнерские ссылки. Подписка на информационный бюллетень означает ваше согласие с нашими Условиями использования и Политикой конфиденциальности. Вы можете отказаться от подписки на информационные бюллетени в любое время.
Читайте также: