Как сделать питон черным
В сообществе Python ещё лет 20 назад осознали ценность форматирования кода, когда на свет появился PEP8 — документ, который призван сделать весь код, написанный на Python, оформленным одинаково и поставить точку в бесконечных спорах о стиле оформления кода. PEP8 и правда глубоко вошёл в идеологию Python. Писать код, который нарушает PEP8 — это считается очень плохой практикой. Это одна из первых заповедей, про которые говорят начинающим питонистам.
Почему же консистентный стиль оформления кода так важен, что этому посвящен целый PEP? Самая главная мысль — читаемость важна. Вот какие ещё мысли у меня возникают по поводу стиля оформления кода.
Следование PEP8 можно автоматически контролировать при помощи таких инструментов, как flake8 или pylint, но тогда форматировать код придётся вручную. Как мы уже выяснили, время разработчика стоит дорого. Можно ли как-то автоматизировать этот процесс?
Кроме того, PEP8 описывает лишь основные правила оформления кода, но оставляет свободу интерпретации во множестве краевых случаев, из-за чего может появиться неконсистентность оформления. Есть ли какие-нибудь более строгие конвенции, чем PEP8?
Почему бескомпромиссный? Потому что black навязывает свой стиль кода, и его практически нельзя конфигурировать. Возможно, вам пока что так не кажется, но это огромный плюс black .
Попробуйте в команде хотя бы из нескольких человек прийти к согласию по поводу того, как код выглядит лучше всего и читается проще всего.
Например, оба варианта абсолютно валидны с точки зрения PEP8, но у каждого стиля есть свои поклонники и противники.
У меня был опыт попытки выработать в команде конвенцию, и это не так просто. Не потому что люди плохие или упрямые, просто у каждого своё понимание красоты и удобства. Наверняка, начнётся борьба вкусов и мнений. black избавляет от всех этих обсуждений — есть готовый стиль оформления кода, где все решения уже приняты за вас.
Да, иногда black выдаёт не самый красивый код, но, если подумать, красота кода не так важна, как консистентность, последовательность, одинаковость. black осознанно приносит красоту в жертву консистентности.
Скажу по собственному опыту, что к отформатированному black коду привыкаешь очень быстро, и буквально через несколько дней просто перестаешь замечать форматирование вообще. Просто читаешь код.
Установка
К сожалению, на момент написания этого поста, black не имеет стабильных релизов, пока что есть только бета-версии. Смею вас заверить, что black даже в бета-версии уже достаточно стабилен и используется в куче серьезных проектов. Правда, отсутствие стабильных релизов немного усложняет установку.
black устанавливается из PyPI. Давайте выясним, какая на данный момент последняя доступная версия при помощи следующего трюка (или можно просто её посмотреть на странице проекта на PyPI):
Команда завершится ошибкой, но выведет список доступных версий. Найдем последнюю доступную версию и запомним её.
Внутри виртуального окружения нужно выполнить, заменив версию на последнюю:
А если вы используете pipenv или poetry , то вот так:
Обратите внимание, что при установке black через pipenv обязательно нужно указывать конкретную версию. Я описал, что произойдёт, если этого не сделать, а взамен разрешить pipenv устанавливать пре-релизные версии в посте про pipenv .
Использование
black имеет очень интуитивный интерфейс командной строки.
Вот так можно отформатировать все файлы в текущей директории (и рекурсивно в поддиректориях):
И это практически единственная команда, которую вам нужно запомнить.
А вот так можно отформатировать один конкретный файл:
Интеграция с редактором/IDE
Очень удобно, когда форматтер запускается прямо из редактора кода автоматически, например, при сохранении файла. black так или иначе можно интегрировать со всеми известными науке редакторами. Процесс подробно описан здесь. Обязательно это сделайте, иначе не ощутите всей прелести автоматического форматирования.
Использование в CI
А ещё нужно настроить запуск black в сервисе для непрерывной интеграции (CI), например, GitHub Actions, GitLab CI или Travis CI. Так black сможет блокировать пулл-реквесты (или мердж-реквесты), в которых содержится неотформатированный код.
В режиме “проверки” black не будет форматировать файлы, а просто напечатает список неотформатированных файлов и завершится кодом ошибки, что должно “уронить” всю проверку целиком.
Конфигурация
Кое-какую минимальную возможность настройки black все-таки предоставляет. Стоит отметить, что в большинстве случаев этого делать не придётся, потому что у black достаточно разумные настройки по умолчанию.
Вот так можно настроить максимальную длину строки и файлы, которые форматировать не нужно. В pyproject.toml в корне проекта добавьте:
Настройка flake8 , чтобы он не противоречил black
У flake8 своё мнение по поводу того, как должен быть отформатирован код, которое не всегда совпадает с мнением black . Чтобы не возникало конфликтов, рекомендуется выключить некоторые проверки flake8 , по примеру того, как это сделано в репозитории black .
Что меня бесит в стиле black
Есть некоторые моменты, с которыми я категорически несогласен. Думаю, рассказать про них тоже нужно.
Рассмотрим пример исходного кода:
Я специально сделал побольше аргументов в функцию print() , чтобы вызов функции стал достаточно длинным, чтобы black разнёс его на несколько строк. Обратите внимание на тернарный оператор. Теперь отформатируем и посмотрим на результат:
Теперь намного понятнее, не правда ли? Такое может произойти не только с тернарными операторами, но и с длинными арифметическими выражениями, и с длинными строками, которые разбиты на несколько частей:
Эта функция имеет два аргумента — булевый и строковый. Отформатируем:
black опять не помог сделать код читаемее. Выглядит так, будто функция имеет три аргумента, хотя на самом деле их только два. Нужно хорошо присмотреться, чтобы заметить отсутствие запятой. Поставим скобки вручную и отформатируем ещё раз:
Стало в сто раз лучше. Теперь всё очевидно.
Надеюсь, что когда-нибудь эту шероховатость починят, а до тех пор я просто вручную ставлю скобки вокруг вот такого некрасивого кода. Такое случается не так уж часто. В целом, даже почти не больно.
Консистентное форматирование кода — это невероятно важно, потому что упрощает восприятие кода другими людьми (или самим же автором кода, но через полгода). Автоматическое форматирование кода (почти) не требует вообще никаких усилий со стороны автора.
Хоть black и имеет свои недостатки, он всё равно явно окупает усилия, затраченные на ручную расстановку скобок, потому что случается это довольно редко. Как и любой инструмент, black дорабатывается, и будем верить, что все проблемы рано или поздно исправят.
black , наряду с flake8 и pytest , попал в мой набор незаменимых инструментов, которые я пытаюсь использовать во всех своих проектах. И вам рекомендую.
Если понравилась статья, то подпишитесь на уведомления о новых постах в блоге, чтобы ничего не пропустить!
Цвет фона по умолчанию графический интерфейс с Tkinter серый. Вы можете изменить это на любой цвет, основанный на требовании вашей заявки.
В этом руководстве мы узнаем, как изменить цвет фона окна Tkinter.
Существует два способа, через которые вы можете изменить цвет фона окна в TKinter. Они есть:
- Использование Настроить (BG = '') Метод класса Tkinter.tk. или же
- напрямую установить свойство BG tkinter.tk.
Пример 1: Изменение цвета фона, используя метод настроителя
В этом примере мы изменим цвет фона окна Tkinter на синий.
Пример 2: Изменение цвета фона с использованием свойства BG
В этом примере мы изменим цвет фона окна Tkinter на синий.
Пример 3: Использование фона для BG
Вы можете использовать имя недвижимости BG Как в приведенных выше двух примерах, или также используйте полную форму Фон Отказ В этом примере мы будем использовать полную форму Фон Чтобы установить цвет фона окна Tkinter.
Пример 4: Использование Hex Code для цвета фона
Как уже упоминалось во время начала, вы можете предоставить шестнадцатеричное эквивалентное значение для цвета. В этом примере мы предоставляем шестнадцатеричное значение для цвета и проверяйте выходные данные.
Резюме
В этом уроке примеров Python мы узнали, как изменить цвет фона окна Tkinter GUI, с помощью хорошо подробного примера Python Python.
Для работы нам требуется установить библиотеку:
>>>pip install colorama
Мы можем установить нужную библиотеку как глобально, так и в изолированную папку - виртуальную среду. Для простоты мы используем первый вариант, хотя рекомендуется использовать второй.
Далее создадим простой Python файл:
from colorama import init, Fore, Back, Style
'''
мы вызываем функцию init(), которая необходима в среде Windows для правильной работы colorama, на других платформах она ничего не делает, поэтому вы можете удалить ее.
'''
Далее определяем все доступные цвета переднего плана в списке "FOREGROUND" и цвета фона в списке "BACKGROUND", мы также определяем список BRIGHTNESS для различных настроек яркости.
FOREGROUND = [ Fore.BLACK, Fore.RED, Fore.GREEN, Fore.YELLOW, Fore.BLUE, Fore.MAGENTA, Fore.CYAN, Fore.WHITE ]
BACKGROUND = [ Back.BLACK, Back.RED, Back.GREEN, Back.YELLOW, Back.BLUE, Back.MAGENTA, Back.CYAN, Back.WHITE ]
BRIGHTNESS = [ Style.DIM, Style.NORMAL, Style.BRIGHT ]
'''
Далее давайте создадим функцию, которая обертывает обычную функцию print() Python, но с возможностью установки цвета и яркости
'''
def print_with_color(s, color=Fore.WHITE, brightness=Style.NORMAL, **kwargs):
"""Служебная функция, обертывающая обычную функцию "печать()"
, но с цветами и яркостью"""
print(f"", **kwargs)
Мы просто используем print() внутри, но дополняем текст яркостью и цветовыми кодами, а также добавляем Style.RESET_ALL в конце, чтобы сбросить цвет и яркость по умолчанию каждый раз, когда мы используем функцию.
Мы также передаем **kwargs, чтобы мы могли использовать другие ключевые аргументы функции print(), такие как end и sep.
Теперь, когда у нас есть наша функция, давайте использовать все цвета переднего плана и напечатаем один и тот же текст разными цветами и каждый с разной яркостью:
for fore in FOREGROUND:
for brightness in BRIGHTNESS:
print_with_color("Myrusakov!", color=fore, brightness=brightness)
При этом черный цвет не будет виден на экране.
Теперь используем фоновые цвета:
for fore in FOREGROUND:
for back in BACKGROUND:
for brightness in BRIGHTNESS:
print_with_color("Myrusakov", color=back+fore, brightness=brightness, end=' ')
print()
Теперь вы знаете все доступные цвета переднего плана и фона, а также значения яркости в библиотеке colorama на Python.
Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления
Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.
Порекомендуйте эту статью друзьям:
Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):
Она выглядит вот так:
Комментарии ( 0 ):
Иногда может потребоваться преобразовать изображение в двоичное. Другими словами, вам нужно преобразовать цветное изображение или изображение в оттенках серого в черно-белое изображение.
Шаги по преобразованию
- Считайте исходное изображение, как изображение в градациях серого.
- Преобразуйте изображение в градациях серого в двоичное с выбранным порогом.
Если исходное изображение является изображением в оттенках серого, то вы можете прочитать изображение на шаге №1, как исходное и продолжить с шага №2. Следующий пример иллюстрирует работу порога при преобразовании серой шкалы в двоичную или черно-белую.
Пример 1
В следующем примере мы прочитаем следующее цветное изображение, используя cv2.imread() в качестве изображения в градациях серого, а затем применим функцию к массиву изображений.
Выходной файл black-and-white.jpg выглядит так, как показано ниже.
Пример 2
В следующем примере мы прочитаем изображение в градациях серого с помощью cv2.imread(), а затем применим функцию к массиву изображений. Нет никакой разницы в преобразовании цветного изображения в черно-белое и в градациях серого в черно-белое.
Читайте также: