首頁 > 軟體

python實現庫存商品管理系統

2022-02-27 13:00:31

本文範例為大家分享了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 = "商品種類: 0n商品總數: 0 n銷售總額: 0n商品均價: 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()

執行結果:

生成兩個檔案:

本要求截圖如下

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com