С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
1 / 1 / 0
Регистрация: 15.11.2021
Сообщений: 228

Заполнение словарей

20.11.2022, 18:34. Показов 610. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Code
1
2
3
productcount={}
cheque={}
product={"Картофель":5,"Лук":10,"Чеснок":8}
Python
1
2
3
4
5
6
7
8
    def SumFromproduct():
        productcount=product
        cheque=product
        for keys in productcount:
            productcount[keys]=int(input("Введите количество продуктов(в кг):"))
        for keys in product:
            cheque[keys]=productcount[keys] * product[keys]
            print(f"Продукт:{product.} —сумма:{cheque[keys]}")
Я хочу сделать сумму по каждому товару(цену за килограмм я ввожу в словаре product), словарь "продукткаунт" служит для держании информации о количестве взятых килограмм, и в словаре "cheque", должна содержатся информация по типу: "товар: цена за килограмм * количество килограмм" , но наверное у меня при копировании словарей что-то пошло не так
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.11.2022, 18:34
Ответы с готовыми решениями:

Поиск по списку словарей и вывод списка словарей
У меня есть список словарей, например: data= Как мне вывести этот список, чтобы каждый словарь был на каждой отдельной строке,...

Сложение словарей
Доброго времени суток. Возникла потребность написать функцию, которая бы выполняла сложение двух одинаковых словарей, т.е. оба словаря...

Список из словарей
Добрый день! Подскажите, пожалуйста, в чем ошибка при решении задачи? Разработчики поменяли формат выгрузки из базы данных товарных...

6
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
20.11.2022, 18:59
ArtemGubarev,
Python
1
2
3
4
product = {"Картофель": 5, "Лук": 10, "Чеснок": 8}
productcount = {"Картофель": 3, "Чеснок": 1}
cheque = {key: value * product[key] for key, value in productcount.items()}
print(cheque)
Code
1
2
3
4
5
{'Картофель': 15, 'Чеснок': 8}
 
 
** Process exited - Return Code: 0 **
Press Enter to exit terminal
0
1 / 1 / 0
Регистрация: 15.11.2021
Сообщений: 228
20.11.2022, 20:32  [ТС]
anton78spb, Не подскажите в чём проблема, при вводе изначального словаря, значение не присваиваются своим "ключам".
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    def Price(self,n):
        for i in range(n):
            name = input("Введите имя продукции:")
            value = int(input("Введите цену продукции(за один кг):"))
            self.product[name] = value
 
    def Chequefromproduct(self):
        self.productcount=self.product
        self.cheque=self.product
        for keys in self.productcount:
            self.productcount[keys]=int(input(f"Введите количество взятых продуктов {keys}(в кг):"))
 
            self.cheque = {key: value * self.product[key] for key, value in self.productcount.items()}
        for keys,value in self.cheque.items():
            print(f"Продукт:{keys}—сумма:{value}")
Миниатюры
Заполнение словарей  
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
20.11.2022, 22:05
Лучший ответ Сообщение было отмечено ArtemGubarev как решение

Решение

ArtemGubarev, Лучше всего выкладывать условия задания, и ваш код целиком. Так гораздо проще работать с ним, и легче помочь.
Python
1
2
3
4
5
6
7
8
    def Chequefromproduct(self):
        self.productcount = {}
        self.cheque = {}
        for key, value in self.product.items():
            self.productcount[key] = int(input(f"Введите количество взятых продуктов {key}(в кг):"))
            self.cheque[key] = self.productcount[key] * value
        for keys, value in self.cheque.items():
            print(f"Продукт:{keys}—сумма:{value}")
Просто если судить по этим кускам кода, то self.productcount у вас вообще лишний. Все решается без него.
Но возможно он вам еще будет где-то нужен, а без полного кода это не понятно.
0
1 / 1 / 0
Регистрация: 15.11.2021
Сообщений: 228
21.11.2022, 13:07  [ТС]
Цитата Сообщение от anton78spb Посмотреть сообщение
self.productcount
Он у меня служит для подсчёта взятых кг определенного продукта,
Цитата Сообщение от ArtemGubarev Посмотреть сообщение
self.cheque
Служит для сохранения суммы по продукту что бы в конце я смог вывести её

Добавлено через 1 минуту
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
from random import  randint
class Market:
 
    def __init__(self):
        self.departmentname=''
        self.product = {}
        self.sumwithoutPDV = 0
        self.sumwithPDV = 0
        self.cheque= {}
        self.NDS = 0.2
        self.chequetime=  0
        self.chequedates = 0
        self.productcode = {}
        self.productcount = {}
    def NameDeaprtment(self,departmentname):
        self.departmentname=departmentname
        return self.departmentname
    def Price(self,n):
        for i in range(n):
            name = input("Введите имя продукции:")
            value = int(input("Введите цену продукции(за один кг):"))
            self.product[name] = value
 
    def Chequefromproduct(self):
        self.productcount=self.product
        self.cheque=self.product
        for keys in self.productcount:
            self.productcount[keys]=int(input(f"Введите количество взятых продуктов {keys}(в кг):"))
 
            self.cheque = {key: value * self.product[key] for key, value in self.productcount.items()}
        for keys,value in self.cheque.items():
            print(f"Продукт:{keys}—сумма:{value}")
 
    def  NDC(self):
             return  self.NDS
    def Code(self,n1):
        self.productcode=self.product
        for keys in self.productcode:
            self.productcode[keys]=randint(100000000000000,9999999999999999)
        print("Код  товара:",self.productcode[n1])
    def SumwithoutPdv(self):
        for i in self.cheque:
            self.sumwithoutPDV += self.cheque[i]
        return  self.sumwithoutPDV
    def SumwithPDV(self):
        self.sumwithPDV=self.sumwithoutPDV*self.NDS
        return  self.sumwithPDV
    def FinallCheque(self):
        print(f"Название отдела:{self.departmentname}\n"
              f"Время покупки:{self.chequetime}-{self.chequedates}")
        for i in range(len(self.cheque)):
            print(f"Товар{self.product[i]}— количество{self.productcount[name]}-сумма по товару{self.cheque[i]}")
        print(f"Остаточная сумма с ПДВ:{self.sumwithPDV}")
 
#time = input("Введите время покупки:")
#date = input("Введите дату покупки:")
market = Market()
while(True):
    func = input("Введите функцию:")
    match(func):
        case 'a':
            name = input("Введите название отдела:")
            market.NameDeaprtment(name)
        case 'b':
            n = int(input("Введите количество товаров:"))
            market.Price(n)
        case 'c':#
            name1=input("Введите точное название товара:")
            market.Code(name1)
        case 'd':#
            market.Chequefromproduct()
        case 'e':
            print("Сумма без ПДВ:",market.SumwithoutPdv())
        case 'f':
            print("ПДВ:",market.NDS)
        case 'g':
            print("Сумма с ПДВ:",market.SumwithPDV())
        case 'h':
            market.FinallCheque()
        case other:
            print("Неверное значение")
Добавлено через 47 секунд
Цитата Сообщение от ArtemGubarev Посмотреть сообщение
def FinallCheque
На этот метод не нужно пока что обращать внимание
0
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
21.11.2022, 15:05
ArtemGubarev, Ок. Постом выше я выложил вам код метода Chequefromproduct. Он полностью решает проблему озвученную вами в первом посте.

Но у вас по всему коду присутствует ошибка. Вы используете простое приравнивание одного словаря к другому. Если вам это действительно надо, то необходимо создавать его копию. А оператор приравнивания просто создает еще одну ссылку на данный словарь. Словарь при это не копируется, он остается тем же самым. Просто на него появляется еще одна ссылка. И работая со второй ссылкой, вы "ломаете" исходный словарь. В методе который я выложил данной проблемы нет. Вы можете подкорректировать остальные методы по такому же принципе. Но если хотите копировать, то используйте метод deepcopy из модуля copy.

Добавлено через 8 минут
Еще пара советов.
1. Почитайте про именование функций и переменных в Python. (Все пишется маленькими буквами, слова разделяются символом подчеркивания).

2. Добавьте меню в начале (соответствие действия и необходимой буквы для активации). Т.к. в таком виде работать с программой стороннему человеку очень тяжело.
2
1 / 1 / 0
Регистрация: 15.11.2021
Сообщений: 228
22.11.2022, 14:13  [ТС]
anton78spb,
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
from random import  randint
from datetime import datetime as dt
 
class Market:
 
    def __init__(self):
        self.department_name=''
        self.product = {}
        self.sum_without_PDV = 0
        self.sum_with_PDV = 0
        self.cheque= {}
        self.NDS = 0.2
        self.cheque_time=  0
        self.cheque_dates = 0
        self.product_code = {}
        self.product_count = {}
    def name_deaprtment(self,department_name):
        self.department_name=department_name
        return self.departmentname
    def price(self,n):
        for i in range(n):
            name = input("Введите имя продукции:")
            value = int(input("Введите цену продукции(за один кг):"))
            self.product[name] = value
 
    def cheque_from_product(self):
        self.product_count = {}
        self.cheque = {}
        for key, value in self.product.items():
            self.product_count[key] = int(input(f"Введите количество взятых продуктов {key}(в кг):"))
            self.cheque[key] = self.product_count[key] * value
        for keys, value in self.cheque.items():
            print(f"Продукт:{keys}—сумма:{value}")
 
    def  NDC(self):
             return  self.NDS
    def code(self,n1):
        self.product_code=self.product
        for keys in self.product_code:
            self.product_code[keys]=randint(100000000000000,9999999999999999)
        print("Код  товара:",self.product_code[n1])
    def sum_without_pdv(self):
        for i in self.cheque:
            self.sum_without_PDV += self.cheque[i]
        return  self.sum_without_PDV
    def sum_with_PDV(self):
        self.sum_with_PDV=self.sum_without_PDV*self.NDS
        return  self.sum_with_PDV
    def finall_cheque(self):
        print(f"Название отдела:{self.department_name}\n")
        for key,value in self.cheque.items():
            print(f"Товар-{key},сумма по товару{value}")
        print(f"Остаточная сумма с ПДВ:{self.sum_with_PDV}")
        print(dt.fromtimestamp(self.cheque_dates.strftime("%Y-%m-%d")),dt.fromtimestamp(self.cheque_time.strftime('T%H:%M')))
 
time = input("Введите время покупки:")
date = input("Введите дату покупки:")
market = Market()
while(True):
    func = input("Введите функцию:")
    match(func):
        case 'a':
            name = input("Введите название отдела:")
            market.name_deaprtment(name)
        case 'b':
            n = int(input("Введите количество товаров:"))
            market.price(n)
        case 'c':#
            name1=input("Введите точное название товара:")
            market.code(name1)
        case 'd':#
            market.cheque_from_product()
        case 'e':
            print("Сумма без ПДВ:",market.sum_without_PDV())
        case 'f':
            print("ПДВ:",market.NDS)
        case 'g':
            print("Сумма с ПДВ:",market.sum_with_PDV())
        case 'h':
            market.finall_cheque()
        case other:
            print("Неверное значение")
Столкнулся с проблемкой, при запросе пользователя информации о коде товара, а после подсчёта сумы по товару, вылезает код товара . Да и с выводом запара хочу реализовать в таком формате
Code
1
2
3
4
Название отдела:
Сума по товару:
Остаточная сума  с ПДВ:
Время действия:(которое вводим, хотя это же можно автоматизировать)
Добавлено через 1 час 57 минут
UPD: переделал всё вышло, не тратьте своё время
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.11.2022, 14:13
Помогаю со студенческими работами здесь

Сортировка словарей
Помогите, пожалуйста, с сортировкой словарей Условие и ожидание закомментированы ниже def exercise3(): horses = #...

Чтения списка словарей
В JSON файле есть список словарей Читаю построчно как список with open('links.json') as f: data = json.load(f) for d in...

Поиск в списках словарей
Имеется 2 списка, состоящие из словарей. Мне нужно было сравнить по id первый и второй список найти соответствующие и если такие есть то...

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

Создание и обработка словарей
Пожалуйста, помогите с решением. Если что-то в условии Вам покажется странно написано, напишите об этом пожалуйста. Задание переведено...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru