标签:体会 保存 输入 模块 script 内存 跟踪 oca 库存
本次我们将运用模块化编程技术来实现一个比较有现实意义的项目---《库存管理系统》。该系统将能实现:
我们可将该系统支持功能细分为以下三类:
按照上面的划分,有助于我们组织整个项目代码。例如,信息存储能够实现包括产品数量、位置等所有信息的存储操作,人机交互部分则能实现对用户诸如添加产品等操作的响应。
相应地,我们就得到三个与之对应的独立模块:
除了以上三个功能模块外,我们还需创建一个源文件作为主项目,让用户能够开启和运行整个库存管理系统,通常命名为main.py。
至此,我们整个项目已包含有四部分,在实现特定功能时通常需要各部分之间的相互协作。比如,生成报告模块需要从数据存储模块获取产品信息。因此,各部分间的交互可由下图进行表示:
到这里,我们就已经完全弄清了整个项目的框架,接下来我们就进一步来分析和搭建各部分模块。
此模块将负责存储整个项目的信息,存储信息总共有三类:产品信息,位置信息,项目信息(产品代码和位置代码组成)。
def set_products(products): global _products _products = products
功能:创建产品信息列表。
输入:产品信息,包括产品代码、描述信息和期望存储数量。将上述信息以元组格式作为参数输入到set_products(products)函数中,产品信息格式如下所示:
[("CODE01", "Product 1", 120), ("CODE02", "Product 2", 100), ... ]
当我们能够输入并创建产品信息后,则需要有进行查看当前产品信息的功能,于是我们需要创建一个返回产品信息函数,如下所示:
def products(): global _products return _products
功能:实现简单的返回产品相关信息,例如通过下面的语句可对整个产品信息列表进行扫描:
for code, description, desired_number in products(): ...
def set_locations(locations): global _locations _locations = locations
功能:创建位置信息列表。
输入:位置信息,包括位置代码和描述信息,同样以元组格式进行存储并作为参数输入到set_locations(locations)函数中。
同样地,我们也需要能够返回产品位置信息的功能,于是创建位置信息返回函数,如下所示:
def locations(): global _locations return _locations
库存中的产品项目信息由产品代码和产品位置代码组成,定义返回库存产品项目信息函数,如下所示:
def items(): global _items return _items
功能:返回产品项目信息,信息返回为元组格式,如下所示:
[("product_code01", "location_code01"), ("product_code02", "location_code02"), ... ]
def add_item(product_code, location_code): global _items _items.append((product_code, location_code)) _save_items()
功能:增添产品项目信息到原始项目信息列表中。
输入:产品代码、位置代码。
def remove_item(product_code, location_code): global _items for i in range(len(_items)): prod_code, loc_code = _items[i] if prod_code == product_code and loc_code == location_code: del _items[i] _save_items() return True return False
功能:移除原始项目信息列表中某条产品项目信息。
输入:产品代码、位置代码。
当程序开始运行时,需要将相关信息数据从硬盘中加载到内存,或者内存中数据保存到硬盘上这样的操作,于是定义初始化函数支持此类操作。
def init(): _load_items()
功能:程序开始运行时,从硬盘文件中加载数据信息。
def _load_items(): global _items if os.path.exists("items.json"): f = open("items.json", "r") _items = json.loads(f.read()) f.close() else: _items = []
功能:从硬盘中名为items的json文件中加载数据到内存中。
def _save_items(): global _items f = open("items.json", "w") f.write(json.dumps(_items)) f.close()
功能:保存内存中数据到硬盘文件。
至此,我们完成了数据存储模块的全部功能函数,它们共同组成了该模块的公共接口以供调用,整体结构如下图所示:
人机交互模块将负责与用户进行交互,包括向用户请求信息和显示信息在屏幕上。这里为了简化,我们仅实现文字交互,运用input()函数向用户请求信息,运用print()函数显示信息在屏幕上。
def prompt_for_action(): ...
功能:响应用户各类操作请求代码,请求代码含义如下表所示:
def prompt_for_product(): ...
功能:显示列表中产品代码信息供用户选择,若用户取消,则返回None。
def prompt_for_location(): ...
功能:显示列表中位置代码信息供用户选择,若用户取消,则返回None。
def show_report(report): print() for line in report: print(line) print()
功能:纯文本格式显示报告内容。
输入:存储报告信息的列表。
def generate_inventory_report(): ...
功能:将当前库存全部产品信息生成报告并显示。
def generate_reorder_report(): ...
功能:将当前需要补充产品信息生成报告并显示。
我们不应该将主项目视为一个模块,而应该将其作为一个标准Python源文件,用户运行此源文件来启动整个项目系统。主项目中需要导入它所需要的各种模块,并调用所定义的各种函数来完成项目的既定任务,它就好比是胶黏剂,将项目各部分全部有机粘合在一起。在Python语言中,这种源文件内通常可见到如下所示的语法框架:
def main(): ... if __name__ == "__main__": main()
整个项目的执行逻辑全部写进main()函数中, 当用户运行此项目时,最后两行程序便会告知系统执行main()函数中的全部逻辑。
对于本次设计的库存管理系统,主项目需要完成的任务有如下:
【注】:步骤3、4无限循环执行直到用户退出。
本次我们用模块化编程技术完成设计和实现了一个跟踪库存产品信息的管理系统,详细地设计并实现了各个功能模块以及模块中的各个功能函数,完整地体验了整个项目的逻辑结构。能够在设计实现过程中体会到模块化编程思想能大大提高设计的灵活性和效率。
本文章属于原创作品,欢迎大家转载分享,禁止修改文章的内容。尊重原创,转载请注明来自:躬耕南阳 https://www.cnblogs.com/yangmi511/
标签:体会 保存 输入 模块 script 内存 跟踪 oca 库存
原文地址:https://www.cnblogs.com/yangmi511/p/12227119.html