Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -121,3 +121,5 @@ dmypy.json

# Pyre type checker
.pyre/

settings.py
23 changes: 19 additions & 4 deletions 1_if1.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,22 +4,37 @@

Условный оператор: Возраст

* Попросить пользователя ввести возраст при помощи input и положить
* Попросить пользователя ввести возраст при помощи input и положить
результат в переменную
* Написать функцию, которая по возрасту определит, чем должен заниматься пользователь:
* Написать функцию, которая по возрасту определит, чем должен заниматься пользователь:
учиться в детском саду, школе, ВУЗе или работать
* Вызвать функцию, передав ей возраст пользователя и положить результат
* Вызвать функцию, передав ей возраст пользователя и положить результат
работы функции в переменную
* Вывести содержимое переменной на экран

"""


def main():
"""
Эта функция вызывается автоматически при запуске скрипта в консоли
В ней надо заменить pass на ваш код
"""
pass

def you_need(your_age):
if 1 <= your_age < 6:
return 'Вам нужно учиться в детском саду'
elif 6 <= your_age < 18:
return 'Вам нужно учиться в школе'
elif 18 <= your_age < 21:
return 'Вам нужно учиться в ВУЗе'
elif 21 <= your_age < 80:
return 'Вам нужно работать'
else:
return 'Вам нужно отдыхать'

print(you_need(int(input('Введите ваш возраст: \n'))))


if __name__ == "__main__":
main()
31 changes: 23 additions & 8 deletions 2_if2.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,22 +5,37 @@
Условный оператор: Сравнение строк

* Написать функцию, которая принимает на вход две строки
* Проверить, является ли то, что передано функции, строками.
* Проверить, является ли то, что передано функции, строками.
Если нет - вернуть 0
* Если строки одинаковые, вернуть 1
* Если строки разные и первая длиннее, вернуть 2
* Если строки разные и вторая строка 'learn', возвращает 3
* Вызвать функцию несколько раз, передавая ей разные праметры
* Вызвать функцию несколько раз, передавая ей разные праметры
и выводя на экран результаты

"""


def strings(str1, str2):
if not isinstance(str1, str) or not isinstance(str2, str):
return 0
elif str1 == str2:
return 1
elif len(str1) > len(str2) and str2 != 'learn':
return 2
elif str2.lower() == 'learn':
return 3
return f'Для строк "{str1}" и "{str2}" нет вывода'


def main():
"""
Эта функция вызывается автоматически при запуске скрипта в консоли
В ней надо заменить pass на ваш код
"""
pass

print(strings('hello', 1))
print(strings('hello', 'world'))
print(strings('qwerty', '123'))
print(strings('learn', 'learn'))
print(strings('learn_python', 'learn'))
print(strings(None, None))


if __name__ == "__main__":
main()
43 changes: 36 additions & 7 deletions 3_for.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

* Дан список словарей с данными по колличеству проданных телефонов
[
{'product': 'iPhone 12', 'items_sold': [363, 500, 224, 358, 480, 476, 470, 216, 270, 388, 312, 186]},
{'product': 'iPhone 12', 'items_sold': [363, 500, 224, 358, 480, 476, 470, 216, 270, 388, 312, 186]},
{'product': 'Xiaomi Mi11', 'items_sold': [317, 267, 290, 431, 211, 354, 276, 526, 141, 453, 510, 316]},
{'product': 'Samsung Galaxy 21', 'items_sold': [343, 390, 238, 437, 214, 494, 441, 518, 212, 288, 272, 247]},
]
Expand All @@ -16,12 +16,41 @@
* Посчитать и вывести среднее количество продаж всех товаров
"""


def sum_sales_for_each_product(lsts):
return [sum(lst["items_sold"]) for lst in lsts]


def avg_sales_for_each_product(lsts):
return [round(sum(lst["items_sold"])/len(lst["items_sold"])) for lst in lsts]


def sum_sales_for_all_products(lsts):
return sum(sum_sales_for_each_product(lsts))


def avg_sales_for_all_products(lsts):
return round(sum_sales_for_all_products(lsts) / len(lsts))

def main():
"""
Эта функция вызывается автоматически при запуске скрипта в консоли
В ней надо заменить pass на ваш код
"""
pass

sales = [
{'product': 'iPhone 12', 'items_sold': [363, 500, 224, 358, 480, 476, 470, 216, 270, 388, 312, 186]},
{'product': 'Xiaomi Mi11', 'items_sold': [317, 267, 290, 431, 211, 354, 276, 526, 141, 453, 510, 316]},
{'product': 'Samsung Galaxy 21', 'items_sold': [343, 390, 238, 437, 214, 494, 441, 518, 212, 288, 272, 247]},
]
for i in range(len(sales)):
print(f'Cуммарное количество продаж товара: "{sales[i]["product"]}" составляет {sum_sales_for_each_product(sales)[i]} шт.')
print('_' * 75)

for i in range(len(sales)):
print(f'Среднее количество продаж товара: "{sales[i]["product"]}" составляет {avg_sales_for_each_product(sales)[i]} шт.')
print('_' * 75)

print(f'Суммарное количество продаж товаров: "{", ".join([sale["product"] for sale in sales])}" составляет {sum_sales_for_all_products(sales)} шт.')
print('_' * 75)

print(f'Среднее количество продаж товаров: "{", ".join([sale["product"] for sale in sales])}" составляет {avg_sales_for_all_products(sales)} шт.')


if __name__ == "__main__":
main()
13 changes: 6 additions & 7 deletions 4_while1.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,17 @@

Цикл while: hello_user

* Напишите функцию hello_user(), которая с помощью функции input() спрашивает
* Напишите функцию hello_user(), которая с помощью функции input() спрашивает
пользователя “Как дела?”, пока он не ответит “Хорошо”

"""


def hello_user():
"""
Замените pass на ваш код
"""
pass
while True:
if input('Как дела?\n').capitalize() == 'Хорошо':
break



if __name__ == "__main__":
hello_user()
19 changes: 12 additions & 7 deletions 5_while2.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,21 @@

Пользователь: Что делаешь?
Программа: Программирую

"""

questions_and_answers = {}
questions_and_answers = {'как дела': 'Отлично!!!', 'кто ты': 'ИИ',
'что делаешь': 'Программирую',
'как тебя зовут': 'Секрет'}


def ask_user(answers_dict):
"""
Замените pass на ваш код
"""
pass

while True:
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

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

question = input('Введите вопрос:\nUser: ').strip().lower()
if question.lower() in ['хватит', 'стоп', 'stop']:
break
print(answers_dict.get(question, 'Не знаю ответ на этот вопрос'))


if __name__ == "__main__":
ask_user(questions_and_answers)
19 changes: 11 additions & 8 deletions 6_exception1.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,20 @@

Исключения: KeyboardInterrupt

* Перепишите функцию hello_user() из задания while1, чтобы она
перехватывала KeyboardInterrupt, писала пользователю "Пока!"
* Перепишите функцию hello_user() из задания while1, чтобы она
перехватывала KeyboardInterrupt, писала пользователю "Пока!"
и завершала работу при помощи оператора break

"""

def hello_user():
"""
Замените pass на ваш код
"""
pass

try:
while True:
if input('Как дела?\n').capitalize() == 'Хорошо':
break
except KeyboardInterrupt:
print('Пока!')


if __name__ == "__main__":
hello_user()
36 changes: 29 additions & 7 deletions 7_exception2.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,19 +10,41 @@
* Первые два нужно приводить к вещественному числу при помощи float(),
а третий - к целому при помощи int() и перехватывать исключения
ValueError и TypeError, если приведение типов не сработало.

"""

def discounted(price, discount, max_discount=20)
"""
Замените pass на ваш код
"""
pass


def discounted(price, discount, max_discount=20):
try:
price = abs(float(price))
except (ValueError, TypeError) as _ex:
return f'Произошла ошибка {_ex}. Проверьте корректность введенной цены товара {price=}.'

try:
discount = abs(float(discount))
except (ValueError, TypeError) as _ex:
return f'Произошла ошибка {_ex}. Проверьте корректность введенной скидки на товар {discount=}.'

try:
max_discount = abs(int(max_discount))
except (ValueError, TypeError) as _ex:
return f'Произошла ошибка {_ex}. Проверьте корректность введенной максимальной ' \
f'скидки на товар {max_discount=}.'

if max_discount >= 100:
raise ValueError("Слишком большая максимальная скидка")
if discount >= max_discount:
return price
else:
return price - (price * discount / 100)


if __name__ == "__main__":
print(discounted(100, 2))
print(discounted(100, "3"))
print(discounted("100", "4.5"))
print(discounted("five", 5))
print(discounted("сто", "десять"))
print(discounted(100.0, 5, "10"))
print(discounted(None, 5, "10.0"))
print(discounted(100, 5, None))
33 changes: 9 additions & 24 deletions 8_ephem_bot.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,42 +13,27 @@

"""
import logging

from telegram.ext import Updater, CommandHandler, MessageHandler, Filters
from settings import API_KEY
from handlers import greet_user, talk_to_me, constellation_planet, guess_number, choice_logo, user_coordinates

logging.basicConfig(format='%(name)s - %(levelname)s - %(message)s',
level=logging.INFO,
filename='bot.log')


PROXY = {
'proxy_url': 'socks5://t1.learn.python.ru:1080',
'urllib3_proxy_kwargs': {
'username': 'learn',
'password': 'python'
}
}


def greet_user(update, context):
text = 'Вызван /start'
print(text)
update.message.reply_text(text)


def talk_to_me(update, context):
user_text = update.message.text
print(user_text)
update.message.reply_text(text)


def main():
mybot = Updater("КЛЮЧ, КОТОРЫЙ НАМ ВЫДАЛ BotFather", request_kwargs=PROXY, use_context=True)
mybot = Updater(API_KEY, use_context=True)

dp = mybot.dispatcher
dp.add_handler(CommandHandler("start", greet_user))
dp.add_handler(CommandHandler("planet", constellation_planet))
dp.add_handler(CommandHandler("guess", guess_number))
dp.add_handler(CommandHandler("logo", choice_logo))
dp.add_handler(MessageHandler(Filters.regex('^(Отправить лого)$'), choice_logo))
dp.add_handler(MessageHandler(Filters.location, user_coordinates))
dp.add_handler(MessageHandler(Filters.text, talk_to_me))

logging.info('Бот стартовал')
mybot.start_polling()
mybot.idle()

Expand Down
Loading