课题35、简单购物车系统 商品,具有编号、名称、类别、单价、库存数量、折扣等信息,实现如下简单购物车功 能: ⑴登录。先登录才能使用本系统。 ⑵浏览商品。 ⑶商品可加入购物车。 ⑷可以查看、修改、删除、清空购物车中的商品。用python

时间: 2023-07-10 21:36:41 浏览: 152
ZIP

python实现简单的购物车功能

好的,下面是一个简单购物车系统的Python实现代码,实现了以上的功能。数据库使用SQLite,需要安装sqlite3库。 ```python import sqlite3 # 连接数据库 conn = sqlite3.connect('shop.db') cursor = conn.cursor() # 创建商品表 cursor.execute(''' CREATE TABLE IF NOT EXISTS products( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, category TEXT, price REAL, stock INTEGER, discount REAL ) ''') # 创建用户表 cursor.execute(''' CREATE TABLE IF NOT EXISTS users( username TEXT PRIMARY KEY, password TEXT ) ''') # 插入商品数据 cursor.execute("INSERT INTO products (name, category, price, stock, discount) VALUES ('Apple', 'Fruit', 5.0, 100, 0.9)") cursor.execute("INSERT INTO products (name, category, price, stock, discount) VALUES ('Banana', 'Fruit', 2.0, 200, 0.8)") cursor.execute("INSERT INTO products (name, category, price, stock, discount) VALUES ('Orange', 'Fruit', 3.0, 150, 0.85)") cursor.execute("INSERT INTO products (name, category, price, stock, discount) VALUES ('Milk', 'Dairy', 4.0, 80, 0.95)") cursor.execute("INSERT INTO products (name, category, price, stock, discount) VALUES ('Bread', 'Bakery', 3.0, 120, 0.9)") # 插入用户数据 cursor.execute("INSERT INTO users (username, password) VALUES ('admin', 'admin')") # 提交事务 conn.commit() # 登录函数 def login(): username = input('请输入用户名:') password = input('请输入密码:') cursor.execute("SELECT * FROM users WHERE username=? AND password=?", (username, password)) if cursor.fetchone(): print('登录成功') return True else: print('用户名或密码错误') return False # 查看商品函数 def show_products(): cursor.execute('SELECT * FROM products') products = cursor.fetchall() print('编号\t名称\t类别\t单价\t库存\t折扣') for product in products: print(f'{product[0]}\t{product[1]}\t{product[2]}\t{product[3]}\t{product[4]}\t{product[5]}') # 加入购物车函数 def add_to_cart(cart, product_id): cursor.execute('SELECT * FROM products WHERE id=?', (product_id,)) product = cursor.fetchone() if product: if product[4] > 0: if product_id in cart: cart[product_id]['count'] += 1 else: cart[product_id] = {'name': product[1], 'price': product[3], 'count': 1, 'discount': product[5]} print(f'{product[1]}加入购物车成功') else: print(f'{product[1]}库存不足') else: print('商品不存在') # 查看购物车函数 def show_cart(cart): if not cart: print('购物车为空') else: total_price = 0 print('编号\t名称\t单价\t数量\t折扣\t总价') for product_id, product_info in cart.items(): price = product_info['price'] * product_info['discount'] count = product_info['count'] total = price * count total_price += total print(f'{product_id}\t{product_info["name"]}\t{price:.2f}\t{count}\t{product_info["discount"]:.2f}\t{total:.2f}') print(f'总价:{total_price:.2f}') # 修改购物车函数 def modify_cart(cart): product_id = input('请输入要修改的商品编号:') if product_id in cart: count = int(input('请输入数量:')) if count > 0: cart[product_id]['count'] = count print(f'{cart[product_id]["name"]}数量修改成功') else: print('数量必须大于零') else: print('商品不存在') # 删除购物车函数 def delete_from_cart(cart): product_id = input('请输入要删除的商品编号:') if product_id in cart: del cart[product_id] print('删除成功') else: print('商品不存在') # 清空购物车函数 def clear_cart(cart): cart.clear() print('购物车已清空') # 主函数 def main(): # 登录 while True: if login(): break # 浏览商品 show_products() # 初始化购物车 cart = {} # 购物 while True: action = input('请选择操作(1.加入购物车 2.查看购物车 3.修改购物车 4.删除购物车 5.清空购物车 6.结算):') if action == '1': product_id = input('请输入要购买的商品编号:') add_to_cart(cart, product_id) elif action == '2': show_cart(cart) elif action == '3': modify_cart(cart) elif action == '4': delete_from_cart(cart) elif action == '5': clear_cart(cart) elif action == '6': show_cart(cart) break else: print('无效操作') # 结束 print('谢谢光临') conn.close() if __name__ == '__main__': main() ``` 在以上代码中,我们首先创建了商品表和用户表,然后插入了一些测试数据。登录函数中,我们从用户表中验证用户信息是否正确。查看商品函数中,我们从商品表中取出所有商品信息并展示给用户。加入购物车函数中,我们从商品表中根据商品编号取出商品信息,并将商品添加到购物车中。查看购物车函数中,我们遍历购物车中的所有商品,并计算总价。修改购物车函数和删除购物车函数中,我们可以根据商品编号对购物车中的商品进行修改和删除。清空购物车函数中,我们可以清空购物车。主函数中,我们实现了购物过程。用户可以选择操作(加入购物车、查看购物车、修改购物车、删除购物车、清空购物车、结算),直到选择结算操作后才结束程序。 以上是一个简单的购物车系统的Python实现代码,可以作为参考。实际项目中,还需要根据具体需求进行设计和开发。
阅读全文

相关推荐

最新推荐

recommend-type

vue实现购物车功能(商品分类)

每个子数组中的对象表示具体的商品,包括`id`、`img`(图片路径)、`name`(商品名称)、`price`(价格)和`num`(商品数量)等属性。 2. **计算属性`alltotal`**: `alltotal`是一个计算属性,用于实时计算购物车...
recommend-type

用JavaScript做简易的购物车的代码示例

在本文中,我们将深入探讨如何使用JavaScript实现一个简单的购物车功能。这个购物车示例主要展示了如何使用原生JavaScript处理用户交互,包括选择商品、更改商品数量和删除商品。我们将分析代码结构,解释各个部分的...
recommend-type

eclipse的web项目实现Javaweb购物车的方法

在实现购物车时,我们需要注意一些常见问题,如购物车中添加商品的数量限制、购物车总计的计算等问题。只有我们解决了这些问题,我们才能实现一个完善的购物车系统。 实现eclipse的web项目实现Javaweb购物车需要...
recommend-type

JavaWeb后台购物车类实现代码详解

Item类的成员变量包括商品id、名称、产地、价格、数量和图片地址等信息。这些成员变量通过setter和getter方法进行访问和修改。除此之外,我们还需要重写hashCode和equals方法,用于判断购物车中是否已经存在相同的...
recommend-type

Android实现商城购物车功能的实例代码

在购物车数据的bean类中,我们需要定义商品的信息,包括商品的id、名称、价格、数量等。这些信息将被用于绑定到布局文件中,并展示在购物车主界面中。 在实现购物车功能时,需要使用到依赖库来实现一些功能,例如...
recommend-type

Python中快速友好的MessagePack序列化库msgspec

资源摘要信息:"msgspec是一个针对Python语言的高效且用户友好的MessagePack序列化库。MessagePack是一种快速的二进制序列化格式,它旨在将结构化数据序列化成二进制格式,这样可以比JSON等文本格式更快且更小。msgspec库充分利用了Python的类型提示(type hints),它支持直接从Python类定义中生成序列化和反序列化的模式。对于开发者来说,这意味着使用msgspec时,可以减少手动编码序列化逻辑的工作量,同时保持代码的清晰和易于维护。 msgspec支持Python 3.8及以上版本,能够处理Python原生类型(如int、float、str和bool)以及更复杂的数据结构,如字典、列表、元组和用户定义的类。它还能处理可选字段和默认值,这在很多场景中都非常有用,尤其是当消息格式可能会随着时间发生变化时。 在msgspec中,开发者可以通过定义类来描述数据结构,并通过类继承自`msgspec.Struct`来实现。这样,类的属性就可以直接映射到消息的字段。在序列化时,对象会被转换为MessagePack格式的字节序列;在反序列化时,字节序列可以被转换回原始对象。除了基本的序列化和反序列化,msgspec还支持运行时消息验证,即可以在反序列化时检查消息是否符合预定义的模式。 msgspec的另一个重要特性是它能够处理空集合。例如,上面的例子中`User`类有一个名为`groups`的属性,它的默认值是一个空列表。这种能力意味着开发者不需要为集合中的每个字段编写额外的逻辑,以处理集合为空的情况。 msgspec的使用非常简单直观。例如,创建一个`User`对象并序列化它的代码片段显示了如何定义一个用户类,实例化该类,并将实例序列化为MessagePack格式。这种简洁性是msgspec库的一个主要优势,它减少了代码的复杂性,同时提供了高性能的序列化能力。 msgspec的设计哲学强调了性能和易用性的平衡。它利用了Python的类型提示来简化模式定义和验证的复杂性,同时提供了优化的内部实现来确保快速的序列化和反序列化过程。这种设计使得msgspec非常适合于那些需要高效、类型安全的消息处理的场景,比如网络通信、数据存储以及服务之间的轻量级消息传递。 总的来说,msgspec为Python开发者提供了一个强大的工具集,用于处理高性能的序列化和反序列化任务,特别是当涉及到复杂的对象和结构时。通过利用类型提示和用户定义的模式,msgspec能够简化代码并提高开发效率,同时通过运行时验证确保了数据的正确性。"
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

STM32 HAL库函数手册精读:最佳实践与案例分析

![STM32 HAL库函数手册精读:最佳实践与案例分析](https://khuenguyencreator.com/wp-content/uploads/2020/07/bai11.jpg) 参考资源链接:[STM32CubeMX与STM32HAL库开发者指南](https://wenku.csdn.net/doc/6401ab9dcce7214c316e8df8?spm=1055.2635.3001.10343) # 1. STM32与HAL库概述 ## 1.1 STM32与HAL库的初识 STM32是一系列广泛使用的ARM Cortex-M微控制器,以其高性能、低功耗、丰富的外设接
recommend-type

如何利用FineReport提供的预览模式来优化报表设计,并确保最终用户获得最佳的交互体验?

针对FineReport预览模式的应用,这本《2020 FCRA报表工程师考试题库与答案详解》详细解读了不同预览模式的使用方法和场景,对于优化报表设计尤为关键。首先,设计报表时,建议利用FineReport的分页预览模式来检查报表的布局和排版是否准确,因为分页预览可以模拟报表在打印时的页面效果。其次,通过填报预览模式,可以帮助开发者验证用户交互和数据收集的准确性,这对于填报类型报表尤为重要。数据分析预览模式则适合于数据可视化报表,可以在这个模式下调整数据展示效果和交互设计,确保数据的易读性和分析的准确性。表单预览模式则更多关注于表单的逻辑和用户体验,可以用于检查表单的流程是否合理,以及数据录入
recommend-type

大学生社团管理系统设计与实现

资源摘要信息:"基于ssm+vue的大学生社团管理系统.zip" 该系统是基于Java语言开发的,使用了ssm框架和vue前端框架,主要面向大学生社团进行管理和运营,具备了丰富的功能和良好的用户体验。 首先,ssm框架是Spring、SpringMVC和MyBatis三个框架的整合,其中Spring是一个全面的企业级框架,可以处理企业的业务逻辑,实现对象的依赖注入和事务管理。SpringMVC是基于Servlet API的MVC框架,可以分离视图和模型,简化Web开发。MyBatis是一个支持定制化SQL、存储过程以及高级映射的持久层框架。 SpringBoot是一种全新的构建和部署应用程序的方式,通过使用SpringBoot,可以简化Spring应用的初始搭建以及开发过程。它使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。 Vue.js是一个用于创建用户界面的渐进式JavaScript框架,它的核心库只关注视图层,易于上手,同时它的生态系统也十分丰富,提供了大量的工具和库。 系统主要功能包括社团信息管理、社团活动管理、社团成员管理、社团财务管理等。社团信息管理可以查看和编辑社团的基本信息,如社团名称、社团简介等;社团活动管理可以查看和编辑社团的活动信息,如活动时间、活动地点等;社团成员管理可以查看和编辑社团成员的信息,如成员姓名、成员角色等;社团财务管理可以查看和编辑社团的财务信息,如收入、支出等。 此外,该系统还可以通过微信小程序进行访问,微信小程序是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或者搜一下即可打开应用。同时,它也实现了应用“用完即走”的理念,用户不用关心是否安装太多应用的问题。应用将无处不在,随时可用,但又无需安装卸载。 总的来说,基于ssm+vue的大学生社团管理系统是一款功能丰富、操作简便、使用方便的社团管理工具,非常适合大学生社团的日常管理和运营。