import sqlite3
Book = sqlite3.connect("BookStore.db")
curbook = Book.cursor()
more=True
total_cost = 0.0
while(more):
Title = input("Enter Title of the book : ")
curbook.execute("SELECT title,author,price FROM BookDetails WHERE title = '"+ Title +"';")
record = curbook.fetchone()
if record == None:
print("No Record Found")
break
else :
print(record)
no_of_copies = int(input("Enter Number of copies you want to purchase : "))
More = input("Add more books? Y/N")
if More == 'n' or More == 'N':
more = False
curbook.execute("SELECT price from BookDetails WHERE title = '"+ Title +"';")
price = curbook.fetchone()
total_cost = total_cost + no_of_copies * price
print("Total Cost ",total_cost)
Book.close()
Ошибка:
Traceback (most recent call last):
File "C:\Python35\Retrieve_Book.py", line 21, in <module>
total_cost = total_cost + no_of_copies * price
TypeError: unsupported operand type(s) for +: 'float' and 'tuple'
fetchone() возвращает кортеж, содержащий данные из требуемых столбцов. Даже если это только один столбец, он все равно возвращает кортеж. Итак, price - это кортеж. Используйте price[0]





price - это кортеж
Пытаться:
total_cost = total_cost + no_of_copies * price[0]
Попробуйте распечатать price, и вы должны увидеть tuple ex: (10,). Вы можете получить доступ к этому элементу с помощью индексации.
В точности как указано в ошибке, либо
no_of_copies, либоpriceявляютсяtuple, а не числами с плавающей запятой.