Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/55: Рейтинг темы: голосов - 55, средняя оценка - 4.65
97 / 20 / 13
Регистрация: 27.02.2018
Сообщений: 60

Класс: Создайте класс, осуществляющий подсчет и изменение числа книг.

26.03.2018, 20:44. Показов 10574. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет форумчане. Задачу решил, и даже проверку проходит , но код не нравится. Подскажите как можно было решить более правильно и в каком месте. ПС когда смотрю туториалы, читаю про ООП, разбитаю чужую задачу вроде все понятно, а как самому написать, возникают траблы. Да и так как я решил , не вижу вообще зачем тут нужно ООП(В плане приемущества решения данной парадигмой).

Вот задача:
Создайте класс, осуществляющий подсчет и изменение числа книг. Названия книг, их количество считываются одной строкой вида 'Boogeyman 66 Battleground 50', число книг - произвольное.
В классе должен быть реализован конструктор, деструктор, методы просмотра числа, взятия и возвращения книг.
Реализовать вывод начальных значений, взятие по 1 книге, возвращение по 1 книге с выводом текущего числа после вызова каждого из методов, меняющих значение книг.
Типичный ответ одной строкой: 'Boogeyman 66 65 66 Battleground 50 49 50'.

Пример входных данных:
Boogeyman 66 Battleground 50

Пример выходных данных:
Boogeyman 66 65 66 Battleground 50 49 50

Вот код:
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
# coding=utf-8
 
 
class Books(object):
 
    def __init__(self):
        pass
 
    def __del__(self):
        pass
 
    def display_book(self, book):
        self.book = book
        return self.book
 
    def take_one_book(self, book):
        self.book = book - 1
        return self.book
    def put_one_book(self, book):
        self.book = book + 1
        return self.book
 
 
a = Books()
 
new_list = list(input().split())
 
for i in new_list:
    if i.isalpha():
        print(i, end=" ")
    if i.isdigit():
        print(a.display_book(int(i)), end=" ")
        print(a.take_one_book(a.display_book(int(i))), end=" ")
        print(a.put_one_book(a.take_one_book(a.display_book(int(i)))), end=" ")
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.03.2018, 20:44
Ответы с готовыми решениями:

Создать класс, представляющий обучающий класс ClassRoom. Создайте класс ученик Pupil. В теле класса создайте методы void
Добрый день.помогите пожалуйста новичку с решением.буду очень благодарен .заранее благодарю.сам не могу решить.хочется посмотреть код ...

Создайте класс точка, имеющая координаты. Класс эллипсов, и класс кругов. Определить иерархию типов
Создайте класс точка, имеющая координаты. Класс эллипсов, и класс кругов. Определить иерархию типов. определить функции печати,...

Создайте класс, представляющий учебную группу Group. Создайте класс студент Student
Используя Visual Studio, создайте проект по шаблону Console Application. Создайте класс, представляющий учебную группу Group. Создайте...

6
 Аватар для Wi0M
395 / 123 / 48
Регистрация: 26.10.2013
Сообщений: 734
26.03.2018, 21:35
А я вот вообще не понял задачу) И решения тоже не понимаю)

26 строка, нет смысла преобразовывать результат .split() в list() потому что split всегда вернет list.

13, 17, 20 строки, нет смысла хранить в классе свойство book так как оно каждый раз перезаписывается, а вот число на которое ты увеличиваешь или уменьшаешь входные данные в методах take_* и put_* лучше вынести в константу класса.

Также из-за того что ты везде в методах класса назвал входной аргумент book совершенно непонятно какой тип дынных в него передавать.

Когда переопределяешь методы супер-класса то вместо pass вызывай метод супер-класса, если ты конечно хочешь что бы он выполнился.

И по идее можно было все 3 твоих метода класса объединить в один __getattr__(self, attr)
1
97 / 20 / 13
Регистрация: 27.02.2018
Сообщений: 60
26.03.2018, 21:42  [ТС]
Цитата Сообщение от Wi0M Посмотреть сообщение
26 строка, нет смысла преобразовывать результат .split() в list() потому что split всегда вернет list.
13, 17, 20 строки, нет смысла хранить в классе свойство book так как оно каждый раз перезаписывается, а вот число на которое ты увеличиваешь или уменьшаешь входные данные в методах take_* и put_* лучше вынести в константу класса.
Также из-за того что ты везде в методах класса назвал входной аргумент book совершенно непонятно какой тип дынных в него передавать.
Когда переопределяешь методы супер-класса то вместо pass вызывай метод супер-класса, если ты конечно хочешь что бы он выполнился.
И по идее можно было все 3 твоих метода класса объединить в один __getattr__(self, attr)
Спасибо, учту когда буду переделывать.
0
 Аватар для blz
151 / 102 / 33
Регистрация: 11.08.2016
Сообщений: 574
26.03.2018, 22:55
Цитата Сообщение от Zarelix Посмотреть сообщение
конструктор, деструктор, методы просмотра числа, взятия и возвращения книг.
1. конструктор у Вас не реализован (логично ему опциоанально передать какой-то начальный список)
2. деструктор. ммм... в питоне в таком классе он не имеет смысла, в детали сборщика мусора здесь вдаваться не место
3. «класс, осуществляющий подсчет и изменение числа книг». КНИГ а не конкретной КНИГИ. А в данной реализации Ваш класс это просто избыточная обертка к числовой переменной, не реализующая никакой дополнительной логики и не предоставляющая ожидаемый уровень абстракции.

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

Добавлено через 56 минут
если привести задачу к более-менее логичному виду, то ее решением будет простой подкласс dict, в котором надо будет реализовать:

а) дополнительный способ инициализации из строки вида «name0 count0 name1 count1 …» примерно таким образом:

l=text.split()
zip(l[::2], [int(n) for n in l[1::2]]) # даст [('name0', count0), ('name1', count1), ('name2', count2)], это годно для конструктора dict()


б) методы инкремента и декремента типа def take1(self, name): self[name] -= 1 и def put1(self, name): self[name] += 1
1
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
27.03.2018, 06:08
В первую очередь, когда создаешь класс, ты должен подумать:

1) а какие поля будут у класса?
2) их названия.
3) их типы (строка, целое, float, список, словарь итд)
4) видимость (public, protected, private). (В питоне, пример: self.books, self._books, self.__books).

А питоне принято объявлять все поля в инициализаторе (в __init__)

Python
1
2
3
4
5
6
class Books(object):
    def __init__(self):
        self._books = {}  # инициализируем поле пустым словарём
 
    def __del__(self):
        self._books = {}  # затираем поле пустым значением
1
0 / 0 / 0
Регистрация: 20.10.2013
Сообщений: 11
03.04.2020, 14:24
тоже этот курс прохожу тихонько
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
class Library(object):
    def __init__(self):
        self.books = {}
 
    def __del__(self):
        self.books = {}
 
    def get_quantity(self, book):
        print(self.books[book], end=' ')
 
    def get_book(self, book):
        self.books[book] -= 1
        print(self.books[book], end=' ')
 
    def return_book(self, book):
        self.books[book] += 1
        print(self.books[book], end=' ')
 
 
a = Library()
books_init = input().split()
 
for i in range(0, len(books_init), 2):
    a.books[books_init[i]] = int(books_init[i + 1])
 
for book in a.books:
    print(book, end=' ')
    a.get_quantity(book)
    a.get_book(book)
    a.return_book(book)
0
0 / 0 / 0
Регистрация: 09.09.2021
Сообщений: 1
09.09.2021, 18:37
Ужасно составлено и сформулировано задание.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
class Book:
    def __init__(self,stroka):
        date = stroka.split()
        self.__kol = dict(zip(date[::2],[int(i) for i in date[1::2]]))
 
    def __del__(self):
        pass
 
    def getval(self, namebook):
        return self.__kol[namebook]
 
    def takebook(self,namebook,val):
        self.__kol[namebook] = self.__kol[namebook] - int(val)
        return self.__kol[namebook]
 
    def addbook(self, namebook, val):
        self.__kol[namebook] = self.__kol[namebook] + int(val)
        return self.__kol[namebook]
 
date_book = 'Boogeyman 66 Battleground 50'
a = Book(date_book)
for book in date_book.split()[::2]:
    print(book,a.getval(book),a.takebook(book,1), a.addbook(book,1))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
09.09.2021, 18:37
Помогаю со студенческими работами здесь

Класс Phone. a) Создайте класс Phone, который содержит переменные number, model и weight. б) Создайте три экземпляра это
Класс Phone. a) Создайте класс Phone, который содержит переменные number, model и weight. б) Создайте три экземпляра этого класса. ...

Создайте класс RightTriangle и Создайте производный класс Rectangle
Создайте класс RightTriangle (Прямоугольный треугольник), задаваемый катетами и опишите механизм вычисления его периметра. Создайте...

Создайте класс, описывающий и реализующий класс-наследник класса треугольник
Создайте класс, описывающий и реализующий класс-наследник класса Object – геометрическую фигуру треугольник с методами вычисления площади и...

Создайте класс «Растение» и класс, который от него наследуется - «Одуванчик»
Создайте класс «Растение». Создайте класс, который от него наследуется «Одуванчик». Основной класс должен иметь минимум 5 параметров....

Создайте класс Квадрат, протестируйте созданный класс в методе Main()
2. Создайте класс Квадрат, определите в нем закрытое свойство СторонаA, методы ввода и вывода свойства, определения периметра и площади....


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru