🐍 Укус питона 🐍
3.08K subscribers
507 photos
2 videos
266 links
🐍 Канал о программировании на языке Python. Тематические уроки и лайфхаки.

👽 Админ - @it_dashka
🔊 Купить рекламу: https://telega.in/c/byteofpython

👉 Чат: @abyteofpython
👉 Поделиться с друзьями: @byteofpython
Download Telegram
Что в результате выведет данный код в консоль?
Anonymous Quiz
12%
SyntaxError
22%
11111111
13%
10
45%
0000000
8%
101
Операторы break и continue

Оператор
break применяется для прерывания текущей итерации цикла. В первом примере цикл прерывается на шестой итерации.

Оператор continue прерывает текущую итерацию без остановки всего цикла. Во втором примере, шестая итерация прерывается до вывода числа в консоль и начинается седьмая.

🐍 Укус питона // 💬 Чат // #теория #циклы #break #continue
Функция split

Метод split используется для разбиения строк на подстроки по разделителю. Функция принимает два необязательных параметра, разделитель и максимальное количество разбиений.

В первом примере, мы не указываем разделитель и метод разделяет строку по умолчанию, по символу пробела.

Далее, мы указываем разделитель ";" и строка разделяется по этому символу. В последнем примере мы указывает вторым параметром в качестве количества разбиений пятерку и строка разбивается на 5 подстрок + оставшиеся элементы.

🐍 Укус питона // 💬 Чат // #теория #строки #методы
Что в результате выведет данный код в консоль?
Anonymous Quiz
9%
False, True, False, True
10%
False, False, False, False
58%
False, True, True, True
12%
SyntaxError
10%
TypeError
Преобразование типов

Процесс преобразования значения переменной одного типа данных (целые числа, строки и т. д.) в другой называется преобразованием типа. Как и во многих других языках программирования преобразование бывает двух типов.

При неявном преобразовании типов, язык сам преобразует один тип данных в другой. Этот процесс не требует нашего участия. В первом примере мы складываем целое число с дробным. В данный момент, язык приводит оба типа к самому сложному из них, т.е к дробному, в результате в ответе мы получаем дробное число.

При явном преобразовании программист сам меняет тип данных, на требуемый, явно указывая тип с помощью функций str, int и float. Во втором примере мы преобразовываем строку в число с помощью функции int.

🐍 Укус питона // 💬 Чат // #типы_данных #строки #числа
Лямбда функции

Лямбда функции позволяют задать функцию анонимно, т.е без имени. Она возвращает объект функции, который присваивается, нужной нам, переменной. Лямбды имеют очень простой синтаксис: lambda аргументы: выражение, поэтому часто их используют когда нужны безымянные функции на небольшой промежуток времени.

В первом примере, наша функция принимает на вход число и возвращает его квадрат. В следующем примере мы готовим приветствие: для пользователя: функция greetings принимает на вход имя и возвращает приветствие с этим именем. В последнем примере мы проверяем число на нечётность.


🐍 Укус питона // 💬 Чат // #теория #функции #лямбды
Что в результате выведет данный код в консоль?
Anonymous Quiz
7%
5
71%
25
6%
SyntaxError
4%
None
11%
Ничего
Функция filter

Функция filter фильтрует элементы итерируемого объекта по заданной функции. Проще говоря, фильтр сохраняет те элементы, для которых функция вернула True.

Функция принимает на вход функцию и итерируемый объект. В примере мы создали функцию is_even которая проверяет число на четность, далее передав функцию в фильтр, мы проверяем список чисел и сохраняем только четные цифры.

🐍 Укус питона // 💬 Чат // #теория #фильтр #filter
Что в результате выведет данный код в консоль?
Anonymous Quiz
10%
SyntaxError
31%
End
44%
Программа уйдет в бесконечный цикл
14%
kotlin, go, java, python
Основы парсинга. Парсим habr.

Парсинг - автоматизированный сбор и структуризация данных в нужном виде. Обычно его используют для быстрого наполнения своих сайтов и каналов контентом или анализа конкурентов. В этом посте мы спарсим статьи с главной страницы хабра.

Для парсинга понадобятся две библиотеки: requests - для http запроса к сайту и beautifulsoup4 - для удобной навигации по html документу. Установить их можно, прописав pip install requests и pip install beautifulsoup4 соответственно.

Далее с помощью метода requests.get получаем главную страницу хабра и передаём её в объект beautifulsoup. Библиотека beautifulsoup позволяет нам с помощью метода select получить список объектов по css-селектору.

Подсматриваем нужные нам селекторы в инспекторе кода браузера и начинаем парсинг. В начале получаем список всех статей. Далее в цикле, также с помощью метода select вытаскиваем нужные нам поля, например название и ссылку. Метод select всегда возвращает список объектов, поэтому если нам нужен только один объект, всегда нужно указать его индекс, например articles[0]. У каждого объекта есть поля и атрибуты, например поле text содержит весь текст в объекте, а в словаре attrs хранятся все атрибуты объекта.

🐍 Укус питона // 💬 Чат // #гайды #библиотеки #парсинг #habr
Что в результате выведет данный код в консоль?
Anonymous Quiz
11%
468
25%
SyntaxError
20%
9753
32%
20
12%
97530
Что в результате выведет данный код в консоль?
Anonymous Quiz
20%
SyntaxError
31%
True
31%
TypeError
18%
False
Основы парсинга. Атрибуты

В прошлом уроке мы разобрали, что такое парсинг и как парсить текст с сайтов. Но часто требуется парсить не только текст, но и картинки, которые хранятся в атрибутах html тегов.
Сегодня мы попробуем спарсить поисковую выдачу с ЛитРес

Снова подсматриваем нужные нам селекторы в инспекторе кода браузера и начинаем парсинг. Получаем список всех книг и начинаем разделять данные. Название и автора книги парсим как в прошлых раз, просто найд элемент через select и вытащив из него поле text.

Но вот ссылку на картинку спарсить таким образом нельзя. Для этого находим класс тега с картинкой, и извлекаем из него атрибут src, с помощью attrs['src'].

ID книги и стоимость лежат в формате json ({ключ: 'значение'}), поэтому с помощью метода find и срезов, находим нужный нам ключ и обрезаем лишнее и выводим всю информацию в консоль.

🐍 Укус питона // 💬 Чат // #гайды #библиотеки #парсинг #атрибуты