Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 18.10.2022
Сообщений: 2

TypeError: unsupported format string passed to NoneType.__format__

03.10.2023, 17:06. Показов 1809. Ответов 3

Студворк — интернет-сервис помощи студентам
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
class InfoMessage:
    """Информационное сообщение о тренировке."""
    def __init__(self,
                 training_type: str,
                 duration: float,
                 distance: float,
                 speed: float,
                 calories: float) -> None:
        self.training_type = training_type
        self.duration = duration
        self.distance = distance
        self.speed = speed
        self.calories = calories
 
    def get_message(self):
        return (f'Тип тренировки: {self.training_type};'
                f'Длительность: {self.duration:.3f} ч.; '
                f'Дистанция: {self.distance:.3f} км; '
                f'Ср.скорость: {self.speed:.3f} км/ч; '
                f'Потрачено ккал: {self.calories:.3f}.')
 
 
class Training:
    """Базовый класс тренировки."""
 
    def __init__(self,
                 action: int,
                 duration: float,
                 weight: float,
                 ) -> None:
        self.action = action
        self.duration = duration
        self.weight = weight
 
    def get_distance(self) -> float:
        """Получить дистанцию в км."""
        LEN_STEP: float = 0.65
        M_IN_KM: int = 1000
        return (self.action * LEN_STEP / M_IN_KM)
 
    def get_mean_speed(self) -> float:
        """Получить среднюю скорость движения."""
        return self.get_distance() / self.duration
 
    def get_spent_calories(self) -> float:  # type: ignore
        """Получить количество затраченных калорий."""
        pass
 
    def show_training_info(self) -> InfoMessage:
        """Вернуть информационное сообщение о выполненной тренировке."""
        return InfoMessage(self.__class__.__name__,
                           self.duration,
                           self.get_distance(),
                           self.get_mean_speed(),
                           self.get_spent_calories())
 
 
class Running(Training):
    """Тренировка: бег."""
 
 
CALORIES_MEAN_SPEED_MULTIPLIER: int = 18
CALORIES_MEAN_SPEED_SHIFT: float = 1.79
IN_MIN: int = 60
 
 
def __init__(self, action: int, duration: float, weight: float,) -> None:
 
    def get_spent_calories(self) -> float:
        return ((CALORIES_MEAN_SPEED_MULTIPLIER * self.get_mean_speed()
                + CALORIES_MEAN_SPEED_SHIFT) * self.weight
                / self.M_IN_KM * self.duration * IN_MIN)
 
 
class SportsWalking(Training):
    """Тренировка: спортивная ходьба."""
    KONST_1: float = 0.035
    KONST_2: float = 0.029
    KONST_3: float = 0.278
 
    def __init__(self,
                 action: int,
                 duration: float,
                 weight: float,
                 height: float) -> None:
        super().__init__(action, duration, weight)
        self.height = height
 
        def get_spent_calories(self) -> float:
            return (((self.KONST_1 * self.weight +
                    ((self.get_mean_speed() * self.KONST_3)**2 / self.height)
                  * self.KONST_2 * self.weight) * self.duration * IN_MIN))
 
 
class Swimming(Training):
    """Тренировка: плавание."""
    LEN_STEP: float = 1.38
    M_IN_KM: int = 1000
 
    def __init__(self, action: int, duration: float, weight: float,
                 length_pool: float, count_pool: float) -> None:
        super().__init__(action, duration, weight)
        self.lenght_pool = length_pool
        self.count_pool = count_pool
 
    def get_distance(self) -> float:  # type: ignore
        """Получить дистанцию в км."""
        return (self.action
                * self.LEN_STEP
                / self.M_IN_KM)
 
    def get_mean_speed(self) -> float:
        return (self.lenght_pool
                * self.count_pool
                / self.M_IN_KM
                / self.duration)
 
    def get_spent_colories(self) -> float:
        return ((self.get_mean_speed() + 1.1) * 2
                * self.weight * self.duration)
 
 
def read_package(workout_type: str, data: list) -> Training:
    """Прочитать данные полученные от датчиков."""
    workout = {
        'SWM': Swimming,
        'RUN': Running,
        'WLK': SportsWalking
    }
 
    return workout[workout_type](*data)
 
 
def main(training: Training) -> None:
    """Главная функция."""
    info = training.show_training_info()
    print(info.get_message())
 
 
if __name__ == '__main__':
    packages = [
        ('SWM', [720, 1, 80, 25, 40]),
        ('RUN', [15000, 1, 75]),
        ('WLK', [9000, 1, 75, 180]),
    ]
 
    for workout_type, data in packages:
        training = read_package(workout_type, data)
        main(training)
вывод ошибки

Traceback (most recent call last):
File "/home/74062/Dev/python/work.py", line 150, in <module>
main(training)
File "/home/74062/Dev/python/work.py", line 138, in main
print(info.get_message())
File "/home/74062/Dev/python/work.py", line 16, in get_message
return (f'Тип тренировки: {self.training_type};'
TypeError: unsupported format string passed to NoneType.__format__
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.10.2023, 17:06
Ответы с готовыми решениями:

TypeError: unsupported operand type(s) for +: 'NoneType' and 'int'
1)Алгоритм вычисления функции F(n), где n – целое неотрицательное число, задан следующими соотношениями: F(n) = 0 при n ≤ 2 или n = 8 ...

TypeError: not enough arguments for format string
Добрый день! Подскажите что неправильно в коде while True: # главный цикл игры print('%s побед, %s поражений, %s поражений,...

TypeError: unsupported operand type(s) for +: 'NoneType' and 'int'
def F(n): if n &gt; 2: return G(n-2) def G(n): if n &gt; 1: return F(n - 1) + n print(F(8))

3
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
04.10.2023, 10:55
gfif7406, Строка 20. Уберите :.3f.
Сделайте вот так:
Python
1
f'Потрачено ккал: {self.calories}.')
И поищите, вы где-то вместо float туда что-то другое (скорее всего строку) передаете.

Добавлено через 17 минут
gfif7406, Скажу точнее, вы туда None присылаете.
Python
1
2
3
    def get_spent_calories(self) -> float:  # type: ignore
        """Получить количество затраченных калорий."""
        pass
0
0 / 0 / 0
Регистрация: 18.10.2022
Сообщений: 2
04.10.2023, 11:31  [ТС]
Цитата Сообщение от anton78spb Посмотреть сообщение
gfif7406, Строка 20. Уберите :.3f.
Сделайте вот так:
Python
1
f'Потрачено ккал: {self.calories}.')
И поищите, вы где-то вместо float туда что-то другое (скорее всего строку) передаете.

Добавлено через 17 минут
gfif7406, Скажу точнее, вы туда None присылаете.
Python
1
2
3
    def get_spent_calories(self) -> float:  # type: ignore
        """Получить количество затраченных калорий."""
        pass
Цитата Сообщение от anton78spb Посмотреть сообщение
gfif7406, Скажу точнее, вы туда None присылаете.
К сожалению не нашёл ни None ни строку которую передаю. я просто недавно изучаю код и возможно просто изза не опытности не замечаю такой ошибки
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
04.10.2023, 12:07
Цитата Сообщение от gfif7406 Посмотреть сообщение
К сожалению не нашёл ни None ни строку которую передаю. я просто недавно изучаю код и возможно просто изза не опытности не замечаю такой ошибки
Ничего не понял. Я же вам уже все нашел. Даже написал функцию от куда None прилетает в конструктор
класса InfoMessage. А он хочет получить float. Но т.к. это Python у вас все "валится" не на этапе компиляции, а во время выполнения.
Как исправить я тоже в посте выше написал. Уберите форматирование для типа float в get_message.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.10.2023, 12:07
Помогаю со студенческими работами здесь

TypeError: unsupported operand type(s) for //: 'NoneType' and 'int'
Код полностью не готов т.к не могу починить ошибку import numpy as np class GiftSet: def __init__(self, *data): ...

TypeError: unsupported operand type(s) for %: 'NoneType' and 'float'
Здравствуйте, имеется код: import math import random #f1 = y**2 #f2 = y*z #f3 = x*y + 2*y #f4 = y ** 3

TypeError: unsupported operand type(s) for +: 'int' and 'NoneType'
def task23(start, end): if start &gt; end and start == 17: return 0 if start == end: return 1 if start &lt;...

TypeError на строке 5: unsupported operand types for +: 'NoneType' and 'int'
Вот задача: https://pythontutor.ru/lessons/inout_and_arithmetic_operations/problems/shoelace/ Вот мое решение: a=int(input()) ...

ERROR - TeleBot: "TypeError occurred, args=("'in <string>' requires string as left operand, not NoneType",)
Добрый день, уважаемые форумчане. Пишу бота. У бота есть команда /help. Как вы знаете, если не переключить раскладку на английский, то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru