Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial branch #147

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
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
18 changes: 14 additions & 4 deletions 1_if1.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@

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

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

Expand All @@ -19,7 +19,17 @@ def main():
Эта функция вызывается автоматически при запуске скрипта в консоли
В ней надо заменить pass на ваш код
"""
pass
def intelect_age(age):
if 0 <= age < 7:
return 'Детский сад'
elif 7 <= age < 18:
return 'Школа'
elif 18 <= age < 22:
return 'ВУЗ'
else:
return 'Работать, никакой пенсии!!!'

intelect_age(int(input('Введите ваш возраст: ')))

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

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

"""
Expand All @@ -20,7 +20,25 @@ def main():
Эта функция вызывается автоматически при запуске скрипта в консоли
В ней надо заменить pass на ваш код
"""
pass


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():
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()
20 changes: 17 additions & 3 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 @@ -21,7 +21,21 @@ def main():
Эта функция вызывается автоматически при запуске скрипта в консоли
В ней надо заменить pass на ваш код
"""
pass

phones_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]},
]
sum_price_sold = 0
sum_item_sold = 0

for phone in phones_sales:
sum_price_sold += sum(phone['items_sold'])
sum_item_sold += len(phone['items_sold'])
print(len(phone['items_sold']))
print(round(sum(phone['items_sold']) / len(phone['items_sold']), 0))

print(round(sum_price_sold / sum_item_sold), 0)

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

Цикл while: hello_user

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

"""


def hello_user():
"""
Замените pass на ваш код
"""
pass
insert_word = input('Как дела? ')
while insert_word.strip().capitalize() != 'Хорошо':
insert_word = input('Как дела? ')



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

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

"""

questions_and_answers = {}
questions_and_answers = {"Как дела": "Хорошо!", "Что делаешь": "Программирую"}

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

text = input("Введите вопрос: ").strip().capitalize()
while text not in questions_and_answers:
text = input("Введите вопрос: ").strip().capitalize()
else:
print(questions_and_answers[text])

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

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

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

"""

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

try:
text = input('Как дела?: ')
except KeyboardInterrupt:
return
while text.strip().capitalize() != 'Хорошо':
try:
text = input('Как дела?: ')

except KeyboardInterrupt:
print('Пока!')
break

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

"""

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

import sys

try:
price = abs(float(price))
except (ValueError, TypeError):
return f'Произошла ошибка {sys.exc_info()[0]}. Проверьте корректность введенной цены товара {price=}.'

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

try:
max_discount = abs(int(max_discount))
except (ValueError, TypeError):
return f'Произошла ошибка {sys.exc_info()[0]}. Проверьте корректность введенной максимальной ' \
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"))
Expand Down
41 changes: 27 additions & 14 deletions 8_ephem_bot.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,43 +12,56 @@
бота отвечать, в каком созвездии сегодня находится планета.

"""
import ephem
import logging

from settings import API_KEY
from telegram.ext import Updater, CommandHandler, MessageHandler, Filters
from datetime import date

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)
update.message.reply_text(f'Привет {update["message"]["chat"]["first_name"]}. {text}')


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


def constellation_planet(update, context):
planets_name = {
'mars': ephem.Mars,
'mercury': ephem.Mercury,
'venus': ephem.Venus,
'jupiter': ephem.Jupiter,
'saturn': ephem.Saturn,
'uranus': ephem.Uranus,
'neptune': ephem.Neptune
}
planet = update.message.text.split()[1].lower()
con_planet = ephem.constellation(planets_name[planet](date.today()))

if planet in planets_name:
update.message.reply_text(
f'Планета {planet.capitalize()} находится в созведии {con_planet[1]} ({con_planet[0]})'
)


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(MessageHandler(Filters.text, talk_to_me))

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

Expand Down