python实现库存商品管理系统
作者:weixin_45564026 发布时间:2023-06-01 06:37:29
标签:python,商品,管理系统
本文实例为大家分享了python实现库存商品管理系统的具体代码,供大家参考,具体内容如下
题目要求:
请设计一个商品管理系统,程序要求根据用户输入的选项进入相应的功能模块,并显示相应的提示信息。若用户输入其他选项时,提示“输入有误”。
程序的功能模块有:
1、添加
程序读取源文件路径下的goodinformation.txt,若没有就创建。当添加的商品已存在时,显示“该商品已存在”
2、查询
根据用户输入的商品名称,查询商品信息,并输出。当查询的商品不存在时,显示“商品库中无该商品”
3、统计
根据goodinformation.xt中的数据,生成统计数据,包括(商品种类,商品总数,销售总额,商品均价),并写入到goodtotal.txt中去
4、退出
退出运行。
提示:
字典、列表、函数、文件的打开和读取等
要求如下:
1.如果具体功能代码无法实现,那么就把程序架构完成,比如罗列需要的函数,并且添加适当的注释。
2.添加测试用例,即根据题目功能,可以写明如果输入为XXX,输出 应该为YYY。
代码入下,为了增强程序的健壮性,使用了re模块防止输入输出出现逗号标点符号不识别的情况。
# 假设文件中的数据按照这样来写:蓝莓,10,20(一行的数据)
import re
def read_goods(fn):
fdic = {}
with open(fn, "r") as f:
for i in f.readlines():
goodl = list(re.split(r"[,,]", i))
goodl = [x.strip() for x in goodl]
fdic[goodl[0]] = goodl
return fdic
def add_goods(fdic, fn):
goods_list = list(re.split('[,,]', input("请输入商品信息(商品名称,单价,数量),直接输入回车退出:")))
if goods_list[0] == "":
return 0
elif len(goods_list) == 3:
try:
a = eval(goods_list[1]) + eval(goods_list[2]) # 防止输入价格时输入非数字符号
except NameError:
print("价格请输入数字符号")
else:
if goods_list[0] in fdic.keys():
print("该商品已存在")
else:
fdic[goods_list[0]] = goods_list
with open(fn, "a") as f:
f.writelines(','.join(goods_list))
f.write("\n")
add_goods(fdic, fn)
else:
if goods_list[0] in fdic.keys():
print("该商品已存在")
else:
print("输入错误请重新输入")
add_goods(fdic, fn)
def find_goods(fdic):
while True:
good_name = input("请输入查询商品名称,直接输入回车退出:")
if good_name == "":
break
else:
for k in fdic.keys():
if k == good_name:
print("{},{:.2f}".format(k, eval(fdic[k][2])))
find_goods(fdic)
return 0
print("商品库中无该商品")
def count(fdic, fn):
type_amount = len(fdic)
good_amount, total_sales, sum_price, ave_price = 0, 0, 0, 0
for v in fdic.values():
good_amount += eval(v[2])
total_sales += eval(v[2]) * eval(v[1])
sum_price += eval(v[1])
try:
ave_price = sum_price / type_amount
with open(fn, "w") as f:
text = "商品种类: " + str(type_amount) + \
"\n商品总数: " + str(good_amount) + \
"\n销售总额: " + str(total_sales) + \
"\n商品均价: " + str(ave_price)
f.write(text)
except ZeroDivisionError:
with open(fn, "w+") as f:
f.seek(0)
text = "商品种类: 0\n商品总数: 0 \n销售总额: 0\n商品均价: 0"
f.write(text)
return print("商品统计数据已写入统计文件")
def main():
goodinfo = "C:\\Users\\13935\\Desktop\\goodinformation.txt" # 换成自己的路径
goodtotal = "C:\\Users\\13935\\Desktop\\goodtotle.txt" # 换成自己的路径
goods_dict = read_goods(goodinfo)
print("1. 查询商品\n2. 添加商品\n3. 统计商品\n4. 退出\n")
while True:
try:
info = eval(input('请输入您的选择:'))
if info == 1:
find_goods(goods_dict)
elif info == 2:
add_goods(goods_dict, goodinfo)
elif info == 3:
count(goods_dict, goodtotal)
elif info == 4:
break
else:
print("输入错误请重新输入")
except NameError:
print("输入错误请重新输入")
return 0
main()
运行结果:
生成两个文件:
本要求截图如下
来源:https://blog.csdn.net/weixin_45564026/article/details/106746024


猜你喜欢
- server:#coding=utf-8from BaseHTTPServer import BaseHTTPRequestHandleri
- 前言摘要之前写了一篇 grpool goroutine池详解 | 协程管理 收到了大家积极的反馈,今天这篇来做一下grpool的性能测试分析
- 1、定义标记变量;利用变量值的变化退出循环# 第一种嵌套形式a = [[1, 2, 3], [5, 5, 6], [7, 8, 9]]# i
- 遇到的问题:在做爬虫的时候,爬取的url链接内还有转义字符,反斜杠 \,打算用正则的re.sub()替换掉的时候遇到了问题,这是要做替换的字
- 今天接到一个小需求,就是想在windows环境下,上传压缩文件到linux指定的目录位置并且解压出来,然后我想了一下,这个可以用python
- 1、HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Applicatio
- 你好,一般情况下,Ctrl+C 是最简单的方法,当无法 Ctrl+C 时,我们借助于 Python,以下是具体步骤:第一步,安装工具库1、t
- 本文介绍了4个asp数据库管理中常用到的access数据库操作程序,一般的网站管理后台都提供了这个功能,方便管理员对数据库数据的管理维护。1
- 摘要:利用xlrd读取excel利用xlwt写excel利用xlutils修改excel利用xlrd读取excel先需要在命令行中pip i
- 本文实例讲述了Scrapy框架基本命令与settings.py设置。分享给大家供大家参考,具体如下:Scrapy框架基本命令1.创建爬虫项目
- 前言接口在软件工程扮演重要角色,随着应用程序的功能不断扩展,代码库的更新和改变也难以管理。在许多情况下,会发现有一些看起来非常相似,但却不相
- Vue路由跳转传参或打开新页面跳转1. 通过路由中的name属性 使用params传递参数, 使用this.$route.para
- 本文实例为大家分享了Python自动循环扔QQ邮箱漂流瓶的具体代码,供大家参考,具体内容如下Python代码如下:# coding=utf-
- 昨天打包下载了一个服务器整站,拿到这个*.mdb的文件后,却不知道怎么用,百度了一下,才知道是一种木马打包的形式文件,不能用WINrar来解
- 该脚本的功能是卸载android手机中安装的所有第三方应用,主要是使用adb shell pm、adb uninstall 命令,所以使用的
- 如何下载最新版本的MySQL?我先去MySQL首页下载最新版本的MySQL-链接:https://www.mysql.com/downloa
- 导入相关的包import pygame, sys, randomfrom pygame.locals import *设置屏幕大小以及基本参
- 这个操作在numpy数组上的操作感觉有点麻烦,但是也没办法。例如 a = [[1,2,3], [4,5,6], [7,8,9]]取 a 的
- 今天需要把一个省外项目的数据库从服务器上备份、拷贝到本机(跨地域传输数据库备份文件)。连上VPN,通过远程桌面连接,连接上服务器,发现数据库
- 为了访问数据库,就要提供数据库连接类,在C#中,是通过Connection类来实现的四种类型的连接方式SQLConnectionADOCon