繁体   English   中英

从 python 程序导出数据我做错了什么?

[英]What am I doing wrong with exporting data from a python program?

我有一个有效的库存程序。 我试图保存保存在一个名为清单的列表中的数据(项目名称和数量)。 因此,它们可以在下次启动和编辑程序时重复使用。

我的库存程序代码:

import os

class Inventory:
    def __init__(self):
        self.item = []
        self.qty = []
    def remove(self, name):
        ix = self.item.index(name)
        self.item.pop(ix)
        self.qty.pop(ix)

    def add(self, name, qty):
        self.item.append(name)
        self.qty.append(qty)

    def update(self, name, update):
        if update >= 0:
            self.qty[self.item.index(name)] += update
        elif update <= -1:
            self.qty[self.item.index(name)] += update

    def search(self, name):
        pos = self.item.index(name) if name in self.item else -1
        if pos >= 0:
            return self.item[pos], self.qty[pos]
        else:
            return None

    def __str__(self):
        out = ""
        zipo = list(zip(self.item, self.qty))
        for foobar in zipo:
            out += f"Item : {foobar[0]} \nQuantity : {foobar[1]}\n"
            out += "----------\n"
        return out


def menuDisplay():
    """Display the menu"""
    print('=============================')
    print('= Inventory Management Menu =')
    print('=============================')
    print('(1) Add New Item to Inventory')
    print('(2) Remove Item from Inventory')
    print('(3) Update Inventory')
    print('(4) Search Item in Inventory')
    print('(5) Print Inventory Report')
    print('(99) Quit')


def add_one_item(inventory):
    print('Adding Inventory')
    print('================')
    while True:
        try:
            new_name = input('Enter the name of the item: ')
            assert new_name.isalpha(), "Only letters are allowed!"
            new_qty = int(input("Enter the quantity of the item: "))
            inventory.add(new_name, new_qty)
            break
        except Exception as e:
            print("Invalid choice! try again! " + str(e))
            print()


def remove_one_item(inventory):
    print('Removing Inventory')
    print('==================')
    removing = input('Enter the item name to remove from inventory: ')
    inventory.remove(removing)


def ask_exit_or_continue():
    return int(input('Enter 98 to continue or 99 to exit: '))


def update_inventory(inventory):
    print('Updating Inventory')
    print('==================')
    item = input('Enter the item to update: ')
    update = int(input(
        "Enter the updated quantity. Enter 5 for additional or -5 for less: "))
    inventory.update(item, update)


def search_inventory(inventory):
    print('Searching Inventory')
    print('===================')
    search = input('Enter the name of the item: ')
    result = inventory.search(search)
    if result is None:
        print("Item not in inventory")
    else:
        name, qty = result
        print('Item:     ', name)
        print('Quantity: ', qty)
        print('----------')


def print_inventory(inventory):
    print('Current Inventory')
    print('=================')
    print(inventory)


def main():
    inventory = Inventory()
    while True:
        try:
            menuDisplay()
            CHOICE = int(input("Enter choice: "))
            if CHOICE in [1, 2, 3, 4, 5]:
                if CHOICE == 1:
                    add_one_item(inventory)
                elif CHOICE == 2:
                    remove_one_item(inventory)
                elif CHOICE == 3:
                    update_inventory(inventory)
                elif CHOICE == 4:
                    search_inventory(inventory)
                elif CHOICE == 5:
                    print_inventory(inventory)
                exit_choice = ask_exit_or_continue()
                if exit_choice == 99:
                    exit()
            elif CHOICE == 99:
                exit()
        except Exception as e:
            print("Invalid choice! try again!"+str(e))
            print()

        # If the user pick an invalid choice,
        # the program will come to here and
        # then loop back.


main()

该程序名为 Cleancopy.py,我正在尝试将数据保存到名为 Inventory 的 TextEdit 文件或 Excel 文档中。

假设在名为清单的列表中导出名称和数量的代码。

我该如何解决? 这是我第一次尝试保存这些数据。 感谢您的时间。

你确定在import osdictVar = eval(strVar)之前没有任何东西吗? 因为如果是这样,那么删除它,它可能会干扰它。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM