结合本学期所学的Python和数据库完成一个零售药店管理系统
零售药店管理系统通过录入零售药品信息、员工信息、客户信息、供应商信息、库房信息和管理员登录信息,实现对药品、员工、客户、供应商、库房和管理员信息的增加、删除、修改和查找四项基本功能,同时能对药店的销售流水、进货信息等记录,并实现数据分析可视化功能,以此决定营业主方向等其他一些功能。
3.1功能需求
3.1.1基本功能
1.基础信息管理:药品信息、员工信息、客户信息、供应商信息等。
2.进货管理:入库登记、入库登记查询、入库报表等。
3.库房管理:库存查询、库存盘点、库存报表等。
4.销售管理:销售登记、销售报表及相应的查询等。
5.系统维护:用户登录管理、系统设置和修改密码。
3.2数据库需求
3.2.1需要存储数据信息
实体
1.药品(药品编号,药品名称,药品价格,供应商,药品数量,所在库房);
2.员工(员工编号,员工姓名,性别,年龄,电话);
3.客户(客户VIP号,姓名,性别,年龄,电话,住址);
4.供应商(供货商编号,供应商名称,供应药品名称,供应商电话,供应商地址);
5.库房(库房编号,名称,地址);
6.管理员登录(序号,用户号,密码);
功能
7.销售流水(销售流水号,销售员工姓名,销售药品编号,销售药品名称,销售日期,销售数量,销售单价,销售总金额);
8.进货(进货日期,库房编号,库房名称,药品名称,药品进价,进货数量);
9.库存(库房名称,药品编号,药品名称,库存量);放入零售药品信息里一起管理
10.登录(用户名,密码);
3.2.2分别对应数据库里的二维表信息
1.Drug(Drugnum,Drugname,Drugprice,DrugSup,Drugnumber,Drughouse);
2.Staff(Staffnum,Staffname,Ssex,Sage,Sphone);
3.Consumers(Cnum,Cname,Csex,Cage,Cphone,Caddress);
4.Suppliers(Supnum,Supname,Supdrug,Supphone,Supaddress);
5.House(Housenum,Housename,Houseaddress);
6.Login(num,name,password);
7.Sale(Salenum,Staffname,Drugnum,Drugname,Saledate,Salenumber,Saleprice,Saletotal);
8.Loadin(Datenum,Housenum,Housename,Drugname,Drugpricein,Drugsum);
4.1数据字典









4.2数据流图


4.3业务流程图

5.1数据库设计
5.1.1概念模型设计







6.1登录功能
伪代码:
1.创建登录窗口;
2.添加“用户名”和“密码”标签以及两个多行文本框;
3.添加“登录”和“退出”两个按钮;
4.连接数据库,检查用户名和密码;
5.登录失败,报出warning警告;
流程图:

import tkinter as tk
from tkinter import messagebox
import pymysql
from MainPage import MainPage
from PIL import Image, ImageTk
def Landing():
root=tk.Tk()
root.geometry('820x400')
root.title('药店员工登录界面')
image_file = Image.open("D:\\百度下载\\12.jpg")
photo = ImageTk.PhotoImage(image_file)
tk.Label(root,image=photo).pack()
username = tk.StringVar()
password = tk.StringVar()
Lable1 = tk.Label(root, text='账号:', font=('Verdana', 13), fg='black')
Lable1.place(relx=0.4, rely=0.4)
entry1 = tk.Entry(root, textvariable=username,width=15, font=('Verdana', 10, 'bold', 'italic'))
entry1.place(relx=0.5, rely=0.4)
Lable2 = tk.Label(root, text='密码:', font=('Verdana', 13), fg='black')
Lable2.place(relx=0.4, rely=0.5)
entry2 = tk.Entry(root, textvariable=password,show='*',width=15, font=('Verdana', 10))
entry2.place(relx=0.5, rely=0.5)
def Login():
db = pymysql.connect(host="localhost", user="root", passwd="12345", db="database")
cur = db.cursor()
sql = f"select * from Login where name='{username}' and password='{password}'"
cur.execute(sql)
db.commit()
data = cur.fetchall()
if data != "":
root.destroy()
MainPage()
else:
messagebox.showwarning(title='警告', message='登陆失败!请检查账号密码输入是否正确!')
tk.Button(root, text="登录", command=Login).place(relx=0.4,rely=0.7)
tk.Button(root, text='退出', command=quit).place(relx=0.55,rely=0.7)
root.mainloop()
if __name__=='__main__':
Landing()
运行效果图

6.2基本操作功能
伪代码:
1.创建主界面窗体;
2.添加“基本操作”菜单;
3.为“基本操作”菜单添加子菜单“零售药品信息”、“员工信息”、“客户信息”、“供应商信息”和“库房信息”;
4.将子菜单“零售药品信息”、“员工信息”、“客户信息”、“供应商信息”和“库房信息”连接数据库,并提供相应的增/删/改/查操作;
流程图:

import tkinter as tk
import Druginfo
import About
import Consumers
import House
import Sale
import Staffinfo
import Suppliersinfo
import Loadin
import Logininfo
import Analyse
from PIL import Image, ImageTk
def MainPage():
top=tk.Tk()
top.title('零售药店管理系统 v0.0.1')
top.geometry('820x400')
image_file = Image.open("D:\\百度下载\\11.jpg")
photo = ImageTk.PhotoImage(image_file)
tk.Label(top,image=photo).pack()
menubar=tk.Menu(top)
menubar1=tk.Menu(menubar)
menubar2=tk.Menu(menubar)
menubar3=tk.Menu(menubar)
menubar4= tk.Menu(menubar)
menubar5=tk.Menu(menubar)
menubar.add_cascade(label='基本操作',menu=menubar1)
menubar1.add_command(label='零售药品信息',command=Druginfo.Drug)
menubar1.add_separator()
menubar1.add_command(label='员工信息', command=Staffinfo.Staff)
menubar1.add_separator()
menubar1.add_command(label='客户信息', command=Consumers.Consumers)
menubar1.add_separator()
menubar1.add_command(label='供应商信息', command=Suppliersinfo.Suppliers)
menubar1.add_separator()
menubar1.add_command(label='库房信息', command=House.House)
menubar.add_cascade(label='系统管理', menu=menubar2)
menubar2.add_command(label='登录管理',command=Logininfo.Login)
menubar.add_cascade(label='财务流通',menu=menubar3)
menubar3.add_command(label='销售记录',command=Sale.Sale)
menubar3.add_separator()
menubar3.add_command(label='进货记录', command=Loadin.Loadin)
menubar.add_cascade(label='数据可视化',menu=menubar4)
menubar4.add_command(label='药品——价格分析',command=Analyse.analyse1)
menubar4.add_separator()
menubar4.add_command(label='药品入库分析',command=Analyse.analyse2)
menubar4.add_separator()
menubar4.add_command(label='进货数量分析',command=Analyse.analyse3)
menubar4.add_separator()
menubar4.add_command(label='进货药品价格分析',command=Analyse.analyse4)
menubar4.add_separator()
menubar4.add_command(label='药品销量分析',command=Analyse.analyse5)
menubar.add_cascade(label='关于', menu=menubar5)
menubar5.add_command(label='帮助', command=About.About)
top['menu']=menubar
top.mainloop()
if __name__=='__main__':
MainPage()
运行效果图





有需要完整代码的同学,希望点赞+收藏,再留言,邮箱地址切勿留错!!!
鉴于好几个铁汁的邮箱都留错了,还是转成网盘吧!
链接:https://pan.baidu.com/s/1UtHRfCE_1EMxvAwVBKtDaQ?pwd=r4pp
提取码:r4pp
我正在使用i18n从头开始构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在rubyonrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
我安装了ruby版本管理器,并将RVM安装的ruby实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby。有没有办法让emacs像shell一样尊重ruby的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
是否有简单的方法来更改默认ISO格式(yyyy-mm-dd)的ActiveAdmin日期过滤器显示格式? 最佳答案 您可以像这样为日期选择器提供额外的选项,而不是覆盖js:=f.input:my_date,as::datepicker,datepicker_options:{dateFormat:"mm/dd/yy"} 关于ruby-on-rails-事件管理员日期过滤器日期格式自定义,我们在StackOverflow上找到一个类似的问题: https://s
我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD