基于Python+Django实现药品管理系统

简介: 基于Python+Django实现药品管理系统

项目编号:BS-Python-001


技术架构:Python+Django


前端:Boostrap


开发工具:IDEA


数据库:sqlite


项目实现的功能:


  用户分三个角色:管理员、仓库管理员、经销商管理员


主要实现的功能包含:药品的进销存操作、客户管理、供应商管理、经营数据统计、数据导出、系统管理等模块


具体功能展示如下:

image.png

库存管理

image.png

image.png

image.png

客户管理

image.png

image.png

供应商管理

image.png

image.png

经营统计分析

image.png

数据导出

image.png

系统管理

image.png

image.png

数据打印

image.png

部分核心代码:

from datetime import datetime
import time
from django.http.response import FileResponse
from django.shortcuts import render, redirect
from hnyhms_app.models import *
import pandas as pd
# 首页
def index(request):
    return render(request, 'index.html', context={'flag': True})
# 登录
def login(request):
    # 用户登录信息判断
    if request.method == "POST":
        # 获取用户登录信息
        username = request.POST.get('username')
        userpass = request.POST.get('userpass')
        # 查询用户信息
        admin_user = Admin_users.objects.filter(au_account=username, au_pwd=userpass).first()
        if admin_user:
            rep = redirect('/adminpage')
            rep.set_cookie('adminuser', username)
            rep.set_cookie('au_role', admin_user.au_role)
            return rep
    rep = render(request, 'index.html', context={'flag': False})
    rep.delete_cookie("adminuser")
    return rep
# 退出登录
def outlogin(request):
    rep = redirect('/')
    rep.delete_cookie("adminuser")
    return rep
# 管理页面
def admin(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    if adminuser is not None:
        # 登录用户信息
        admin_user = Admin_users.objects.get(au_account=adminuser)
        admin_user_name = admin_user.au_name
        admin_user_role = admin_user.au_role
        if admin_user_role == 1:
            return render(request, 'admin_1.html', context={'admin_user_name': admin_user_name})
        if admin_user_role == 2:
            return render(request, 'admin_2.html', context={'admin_user_name': admin_user_name})
        if admin_user_role == 3:
            return render(request, 'admin_3.html', context={'admin_user_name': admin_user_name})
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 库存管理
def kcpg(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        # 判断是否有查询信息
        if request.GET.get('s') is None or request.GET.get('s') == '':
            # 返回全部列表
            medicines_list = Medicines.objects.all().values()
            customers_suppliers = Customers_suppliers.objects.filter(cs_attitude='供应商').values()
            warehouse_record = Warehouse_record.objects.all()
            context = {'medicines': medicines_list, 'customers_suppliers': customers_suppliers, 'warehouse_record': warehouse_record}
            return render(request, 'funcpage/kcpg.html', context=context)
        # 返回符合查询内容的列表
        medicines_list = Medicines.objects.filter(medicine_name__contains=request.GET.get('s')).values()
        customers_suppliers = Customers_suppliers.objects.filter(cs_attitude='供应商').values()
        warehouse_record = Warehouse_record.objects.all().values()
        context = {'medicines': medicines_list, 'customers_suppliers': customers_suppliers, 'warehouse_record': warehouse_record}
        return render(request, 'funcpage/kcpg.html', context=context)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 药品入库页面
def in_medicine(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine_id = request.GET.get('id')
        medicine_data = list(Medicines.objects.filter(id=medicine_id).values())[0]
        customers_suppliers = Customers_suppliers.objects.filter(cs_attitude='供应商').values()
        return render(request, 'funcpage/in_medicine.html', context={'medicine_data': medicine_data, 'customers_suppliers': customers_suppliers})
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 药品出库
def out_medicine(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine_id = request.GET.get('id')
        medicine_data = list(Medicines.objects.filter(id=medicine_id).values())[0]
        customers_suppliers = Customers_suppliers.objects.filter(cs_attitude='客户').values()
        return render(request, 'funcpage/out_medicine.html', context={'medicine_data': medicine_data, 'customers_suppliers': customers_suppliers})
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 药品入库保存
def in_medicine_save(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine = Medicines.objects.filter(id=request.POST.get('id'))
        medicine.update(medicine_quantity = medicine[0].medicine_quantity + float(request.POST.get('medicine_quantity')))
        # 进货金额计算
        in_amount = float(request.POST.get('medicine_quantity')) * float(request.POST.get('medicine_purchase'))
        # 添加入库记录
        warehouse_record = Warehouse_record(wr_in_out = '入库', 
                            wr_quantity = request.POST.get('medicine_quantity'),
                            wr_cs_name = request.POST.get('medicine_suppliers'),
                            wr_admin_name = request.COOKIES.get('adminuser'),
                            wr_medicine_name = request.POST.get('medicine_name'),
                            wr_in_out_time = time.strftime("%Y-%m-%d", time.localtime()),
                            wr_amount = in_amount)
        warehouse_record.save()
        return redirect('/kcpg')
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 药品出库保存
def out_medicine_save(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine = Medicines.objects.filter(id=request.POST.get('id'))
        if medicine[0].medicine_quantity >= float(request.POST.get('medicine_quantity')):
            medicine.update(medicine_quantity = medicine[0].medicine_quantity - float(request.POST.get('medicine_quantity')))
            # 出货金额计算
            out_amount = float(request.POST.get('medicine_quantity')) * float(request.POST.get('medicine_selling'))
            # 添加出库记录
            warehouse_record = Warehouse_record(wr_in_out = '出库', 
                                wr_quantity = request.POST.get('medicine_quantity'),
                                wr_cs_name = request.POST.get('medicine_suppliers'),
                                wr_admin_name = request.COOKIES.get('adminuser'),
                                wr_medicine_name = request.POST.get('medicine_name'),
                                wr_in_out_time = time.strftime("%Y-%m-%d", time.localtime()),
                                wr_amount = out_amount)
            warehouse_record.save()
            return redirect('/kcpg')
        else:
            return render(request, 'funcpage/error.html', context={'info': '库存数量已不够出库,请返回或重新填写出库数量', 'up': '/kcpg'}, status=403)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 新增药品保存
def add_medicine(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        # 药品保存
        medicine = Medicines(medicine_name = request.POST.get('medicine_name'), 
                            medicine_manufacturers = request.POST.get('medicine_manufacturers'), 
                            medicine_trademark = request.POST.get('medicine_trademark'), 
                            medicine_production_address = request.POST.get('medicine_production_address'), 
                            medicine_code = request.POST.get('medicine_code'), 
                            medicine_specification = request.POST.get('medicine_specification'), 
                            medicine_purchase = request.POST.get('medicine_purchase'), 
                            medicine_selling = request.POST.get('medicine_selling'))
        medicine.save()
        return redirect("/kcpg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 药品编辑页面
def edit_medicine_page(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine_id = request.GET.get('id')
        medicine_data = list(Medicines.objects.filter(id=medicine_id).values())[0]
        return render(request, 'funcpage/edit_medicine.html', context={'medicine_data': medicine_data})
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 药品编辑保存
def edit_medicine_save(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine = Medicines.objects.filter(id=request.POST.get('id'))
        medicine.update(medicine_name=request.POST.get('medicine_name'),
                        medicine_manufacturers = request.POST.get('medicine_manufacturers'),
                        medicine_trademark = request.POST.get('medicine_trademark'),
                        medicine_production_address = request.POST.get('medicine_production_address'),
                        medicine_code = request.POST.get('medicine_code'),
                        medicine_specification = request.POST.get('medicine_specification'),
                        medicine_purchase = request.POST.get('medicine_purchase'),
                        medicine_selling = request.POST.get('medicine_selling'))
        return redirect('/kcpg')
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 删除库存
def del_medicine(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 2):
        medicine = Medicines.objects.get(id = request.GET.get('id'))
        medicine.delete()
        return redirect("/kcpg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 客户管理
def khpg(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        # 判断是否有查询信息
        if request.GET.get('s') is None or request.GET.get('s') == '':
            customers_suppliers = Customers_suppliers.objects.filter(
            cs_attitude='客户').values()
            context = {'customers_suppliers': customers_suppliers}
            return render(request, 'funcpage/khpg.html', context=context)
        # 返回符合查询内容的列表
        customers_suppliers = Customers_suppliers.objects.filter(cs_unit__contains = request.GET.get('s')).values()
        context = {'customers_suppliers': customers_suppliers}
        return render(request, 'funcpage/khpg.html', context=context)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 新增客户
def add_customers(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        customers = Customers_suppliers(cs_attitude = request.POST.get('cs_attitude'), 
                            cs_postCode = request.POST.get('cs_postCode'), 
                            cs_address = request.POST.get('cs_address'), 
                            cs_tel = request.POST.get('cs_tel'), 
                            cs_unit = request.POST.get('cs_unit'), 
                            cs_name = request.POST.get('cs_name'))
        customers.save()
        return redirect("/khpg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 客户编辑页面
def edit_customers_page(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        customers_id = request.GET.get('id')
        customers_data = list(Customers_suppliers.objects.filter(id=customers_id).values())[0]
        return render(request, 'funcpage/edit_customers.html', context=customers_data)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 客户编辑保存
def edit_customers_save(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        medicine = Customers_suppliers.objects.filter(id=request.POST.get('id'))
        medicine.update(cs_postCode=request.POST.get('cs_postCode'),
                        cs_address = request.POST.get('cs_address'),
                        cs_tel = request.POST.get('cs_tel'),
                        cs_unit = request.POST.get('cs_unit'),
                        cs_name = request.POST.get('cs_name'))
        return redirect('/khpg')
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 删除客户
def del_customers(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        customers_suppliers = Customers_suppliers.objects.get(id = request.GET.get('id'))
        customers_suppliers.delete()
        return redirect("/khpg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 供应商管理
def gyspg(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        # 判断是否有查询信息
        if request.GET.get('s') is None or request.GET.get('s') == '':
            customers_suppliers = Customers_suppliers.objects.filter(
            cs_attitude='供应商').values()
            context = {'customers_suppliers': customers_suppliers}
            return render(request, 'funcpage/gyspg.html', context=context)
        # 返回符合查询内容的列表
        customers_suppliers = Customers_suppliers.objects.filter(cs_unit__contains = request.GET.get('s')).values()
        context = {'customers_suppliers': customers_suppliers}
        return render(request, 'funcpage/gyspg.html', context=context)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 新增供应商
def add_suppliers(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        suppliers = Customers_suppliers(cs_attitude = request.POST.get('cs_attitude'), 
                            cs_postCode = request.POST.get('cs_postCode'), 
                            cs_address = request.POST.get('cs_address'), 
                            cs_tel = request.POST.get('cs_tel'),
                            cs_unit = request.POST.get('cs_unit'), 
                            cs_name = request.POST.get('cs_name'))
        suppliers.save()
        return redirect("/gyspg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 供应商编辑页面
def edit_suppliers_page(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        suppliers_id = request.GET.get('id')
        suppliers_data = list(Customers_suppliers.objects.filter(id=suppliers_id).values())[0]
        return render(request, 'funcpage/edit_suppliers.html', context=suppliers_data)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 供应商编辑保存
def edit_suppliers_save(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        suppliers = Customers_suppliers.objects.filter(id=request.POST.get('id'))
        suppliers.update(cs_postCode=request.POST.get('cs_postCode'),
                        cs_address = request.POST.get('cs_address'),
                        cs_tel = request.POST.get('cs_tel'),
                        cs_unit = request.POST.get('cs_unit'),
                        cs_name = request.POST.get('cs_name'))
        return redirect('/gyspg')
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 删除供应商
def del_suppliers(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1 or admin_user_role == 3):
        customers_suppliers = Customers_suppliers.objects.get(id = request.GET.get('id'))
        customers_suppliers.delete()
        return redirect("/gyspg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 统计分析
def tjpg(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        try:
            # 年销售额/成本/占比
            # 年数据
            year_data = {}
            now_year = datetime.now().year
            year_in_warehouse_record = pd.DataFrame(Warehouse_record.objects.filter(wr_in_out = '入库', wr_in_out_time__year = now_year).values())
            year_out_warehouse_record = pd.DataFrame(Warehouse_record.objects.filter(wr_in_out = '出库', wr_in_out_time__year = now_year).values())
            # 年收入
            year_data['year_income'] = sum(year_out_warehouse_record['wr_amount'])
            # 年支出
            year_data['year_expenditure'] = sum(year_in_warehouse_record['wr_amount'])
            # 年利润
            year_data['year_profit'] = year_data['year_income'] - year_data['year_expenditure']
            # 年盈亏比
            year_data['year_ratio'] = round((year_data['year_profit'] / year_data['year_expenditure']) * 100, 3)
            # 月销售额/成本/占比
            # 月数据
            month_data = {}
            now_month = datetime.now().month
            month_in_warehouse_record = pd.DataFrame(Warehouse_record.objects.filter(wr_in_out = '入库', wr_in_out_time__month = now_month).values())
            month_out_warehouse_record = pd.DataFrame(Warehouse_record.objects.filter(wr_in_out = '出库', wr_in_out_time__month = now_month).values())
            # 月收入
            month_data['month_income'] = sum(month_out_warehouse_record['wr_amount'])
            # 月支出
            month_data['month_expenditure'] = sum(month_in_warehouse_record['wr_amount'])
            # 月利润
            month_data['month_profit'] = month_data['month_income'] - month_data['month_expenditure']
            # 月盈亏比
            month_data['month_ratio'] = round((month_data['month_profit'] / month_data['month_expenditure']) * 100, 3)
            # 药品排行
            medicine_ranking = {}
            # 年药品排行
            year_medicine = pd.DataFrame(Warehouse_record.objects.filter(wr_in_out = '出库', wr_in_out_time__year = now_year).values())
            year_medicine = year_medicine.sort_values('wr_amount')
            year_medicine_ranking = year_medicine.groupby(['wr_medicine_name'])['wr_amount'].sum()[::-1]
            medicine_ranking['year_medicine_ranking'] = year_medicine_ranking.to_dict()
            # 月药品排行
            month_medicine = pd.DataFrame(Warehouse_record.objects.filter(wr_in_out = '出库', wr_in_out_time__month = now_month).values())
            month_medicine = month_medicine.sort_values('wr_amount')
            month_medicine_ranking = month_medicine.groupby(['wr_medicine_name'])['wr_amount'].sum()[::-1]
            medicine_ranking['month_medicine_ranking'] = month_medicine_ranking.to_dict()
            # 盈利亏损情况
            pl = {}
            pl['year'] = True
            pl['month'] = True
            if year_data['year_profit'] < 0:
                pl['year'] = False
            if month_data['month_profit'] < 0:
                pl['month'] = False
            context = {'year_data': year_data, 'month_data': month_data, 'medicine_ranking': medicine_ranking, 'pl': pl}
            return render(request, 'funcpage/tjpg.html', context=context)
        except:
            return render(request, 'funcpage/error.html', context={'info': '现有出入库数据无法进行统计分析!', 'up': ''})
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 库存数据下载
def down_kc(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        # 生成数据文件
        data = pd.DataFrame(Medicines.objects.all().values())
        data.to_excel('hnyhms_app/data_file/kc_data.xls', index=False)
        # 返回文件
        file = open('hnyhms_app/data_file/kc_data.xls', 'rb')
        response = FileResponse(file)
        response['Content-Type'] = 'application/octet-stream'
        response['Content-Disposition'] = 'attachment;filename="kc_data_' + datetime.strftime(datetime.now(),'%Y-%m-%d %H:%M:%S') + '.xls"'
        return response
    return render(request, 'funcpage/error.html', context={'info': '您没有权限下载文件!', 'up': '/'})
# 出入库记录下载
def down_io(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        # 生成数据文件
        data = pd.DataFrame(Warehouse_record.objects.all().values())
        data.to_excel('hnyhms_app/data_file/io_data.xls', index=False)
        # 返回文件
        file = open('hnyhms_app/data_file/io_data.xls', 'rb')
        response = FileResponse(file)
        response['Content-Type'] = 'application/octet-stream'
        response['Content-Disposition'] = 'attachment;filename="io_data_' + datetime.strftime(datetime.now(),'%Y-%m-%d %H:%M:%S') + '.xls"'
        return response
    return render(request, 'funcpage/error.html', context={'info': '您没有权限下载文件!', 'up': '/'})
# 客户数据下载
def down_kh(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        # 生成数据文件
        data = pd.DataFrame(Customers_suppliers.objects.filter(cs_attitude='客户').values())
        data.to_excel('hnyhms_app/data_file/cs_data.xls', index=False)
        # 返回文件
        file = open('hnyhms_app/data_file/cs_data.xls', 'rb')
        response = FileResponse(file)
        response['Content-Type'] = 'application/octet-stream'
        response['Content-Disposition'] = 'attachment;filename="cs_data_' + datetime.strftime(datetime.now(),'%Y-%m-%d %H:%M:%S') + '.xls"'
        return response
    return render(request, 'funcpage/error.html', context={'info': '您没有权限下载文件!', 'up': '/'})
# 供应商数据下载
def down_gys(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        # 生成数据文件
        data = pd.DataFrame(Customers_suppliers.objects.filter(cs_attitude='供应商').values())
        data.to_excel('hnyhms_app/data_file/gys_data.xls', index=False)
        # 返回文件
        file = open('hnyhms_app/data_file/gys_data.xls', 'rb')
        response = FileResponse(file)
        response['Content-Type'] = 'application/octet-stream'
        response['Content-Disposition'] = 'attachment;filename="gys_data_' + datetime.strftime(datetime.now(),'%Y-%m-%d %H:%M:%S') + '.xls"'
        return response
    return render(request, 'funcpage/error.html', context={'info': '您没有权限下载文件!', 'up': '/'})
# 系统管理
def xtpg(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        admin_users = Admin_users.objects.all().values()
        context = {'admin_users': admin_users}
        return render(request, 'funcpage/xtpg.html', context=context)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 新增管理员
def add_admin_users(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        admin_users = Admin_users(au_name = request.POST.get('au_name'), 
                            au_account = request.POST.get('au_account'), 
                            au_pwd = request.POST.get('au_pwd'), 
                            au_role = request.POST.get('au_role'), 
                            au_tel = request.POST.get('au_tel'))
        admin_users.save()
        return redirect("/xtpg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 管理员编辑页面
def edit_admin_page(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        admin_id = request.GET.get('id')
        admin_data = list(Admin_users.objects.filter(id=admin_id).values())[0]
        return render(request, 'funcpage/edit_admin.html', context=admin_data)
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 管理员编辑保存
def edit_admin_save(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        admin = Admin_users.objects.filter(id=request.POST.get('id'))
        if request.POST.get('au_pwd') == '':
            admin.update(au_name=request.POST.get('au_name'),
                        au_account = request.POST.get('au_account'),
                        au_role = request.POST.get('au_role'),
                        au_tel = request.POST.get('au_tel'))
        else:
            admin.update(au_name=request.POST.get('au_name'),
                            au_account = request.POST.get('au_account'),
                            au_pwd = request.POST.get('au_pwd'),
                            au_role = request.POST.get('au_role'),
                            au_tel = request.POST.get('au_tel'))
        return redirect('/xtpg')
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
# 删除管理员
def del_adminuser(request):
    # 收到浏览器的再次请求,判断浏览器携带的cookie是不是登录成功的时候响应的cookie
    adminuser = request.COOKIES.get('adminuser')
    # 权限判断
    admin_user_role = Admin_users.objects.get(au_account = adminuser).au_role
    if adminuser is not None and (admin_user_role == 1):
        admin_users = Admin_users.objects.get(id = request.GET.get('id'))
        admin_users.delete()
        return redirect("/xtpg")
    return render(request, 'funcpage/error.html', context={'info': '您没有权限访问该页面!', 'up': '/'}, status=403)
from django.db import models
# Create your models here.
# 管理员
class Admin_users(models.Model):
    au_name = models.CharField('姓名', max_length=30)
    au_account = models.CharField('账号', max_length=30)
    au_pwd = models.CharField('密码', max_length=30)
    au_role = models.IntegerField('角色', default=2)
    au_tel = models.CharField('电话', max_length=30)
    def __str__(self):
        return self.au_name
    class Meta:
        verbose_name = '管理员'
        verbose_name_plural = '管理员'
# 供应商和客户
class Customers_suppliers(models.Model):
    cs_attitude = models.CharField('供应商/客户', max_length=20)
    cs_postCode = models.IntegerField('邮编', default=0)
    cs_address = models.CharField('地址', max_length=50)
    cs_tel = models.CharField('电话', max_length=20)
    cs_unit = models.CharField('单位', max_length=30)  # 单位
    cs_name = models.CharField('联系人', max_length=30)  # 联系人
    def __str__(self):
        return self.cs_unit
    class Meta:
        verbose_name = '供应商和客户'
        verbose_name_plural = '供应商和客户'
# 药品
class Medicines(models.Model):
    medicine_name = models.CharField('药品名', max_length=30)
    medicine_manufacturers = models.CharField('生产商', max_length=30)  # 生产商
    medicine_trademark = models.CharField('品牌', max_length=30)  # 品牌
    medicine_production_address = models.CharField('生产地址', max_length=50)  # 生产地址
    medicine_code = models.CharField('条码号', max_length=30)
    medicine_specification = models.CharField('规格', max_length=20)  # 规格
    medicine_purchase = models.FloatField('进货价', default=0)  # 进货价
    medicine_selling = models.FloatField('出售价', default=0)  # 出售价
    medicine_quantity = models.IntegerField('数量', default=0)  # 出售价
    def __str__(self):
        return self.medicine_name
    class Meta:
        verbose_name = '药品'
        verbose_name_plural = '药品'
# 出入库
class Warehouse_record(models.Model):
    wr_in_out = models.CharField('入库/出库', max_length=20)
    wr_quantity = models.IntegerField('数量', default=0)  # 出入库量
    wr_cs_name = models.CharField('供应商/客户', max_length=20)
    wr_admin_name = models.CharField('记录管理员', max_length=20)
    wr_medicine_name = models.CharField('药品名', max_length=20)
    wr_in_out_time = models.DateField('时间', auto_now=True)
    wr_amount = models.FloatField('金额', default=0)
    class Meta:
        verbose_name = '出入库记录'
        verbose_name_plural = '出入库记录'
相关文章
|
3天前
|
机器学习/深度学习 人工智能 算法
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
眼疾识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了4种常见的眼疾图像数据集(白内障、糖尿病性视网膜病变、青光眼和正常眼睛) 再使用通过搭建的算法模型对数据集进行训练得到一个识别精度较高的模型,然后保存为为本地h5格式文件。最后使用Django框架搭建了一个Web网页平台可视化操作界面,实现用户上传一张眼疾图片识别其名称。
20 4
基于Python深度学习的眼疾识别系统实现~人工智能+卷积网络算法
|
25天前
|
机器学习/深度学习 人工智能 算法
猫狗宠物识别系统Python+TensorFlow+人工智能+深度学习+卷积网络算法
宠物识别系统使用Python和TensorFlow搭建卷积神经网络,基于37种常见猫狗数据集训练高精度模型,并保存为h5格式。通过Django框架搭建Web平台,用户上传宠物图片即可识别其名称,提供便捷的宠物识别服务。
245 55
|
2月前
|
机器学习/深度学习 数据采集 供应链
使用Python实现智能食品安全追溯系统的深度学习模型
使用Python实现智能食品安全追溯系统的深度学习模型
76 4
|
13天前
|
存储 缓存 监控
局域网屏幕监控系统中的Python数据结构与算法实现
局域网屏幕监控系统用于实时捕获和监控局域网内多台设备的屏幕内容。本文介绍了一种基于Python双端队列(Deque)实现的滑动窗口数据缓存机制,以处理连续的屏幕帧数据流。通过固定长度的窗口,高效增删数据,确保低延迟显示和存储。该算法适用于数据压缩、异常检测等场景,保证系统在高负载下稳定运行。 本文转载自:https://www.vipshare.com
107 66
|
1月前
|
机器学习/深度学习 人工智能 算法
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
宠物识别系统,本系统使用Python作为主要开发语言,基于TensorFlow搭建卷积神经网络算法,并收集了37种常见的猫狗宠物种类数据集【'阿比西尼亚猫(Abyssinian)', '孟加拉猫(Bengal)', '暹罗猫(Birman)', '孟买猫(Bombay)', '英国短毛猫(British Shorthair)', '埃及猫(Egyptian Mau)', '缅因猫(Maine Coon)', '波斯猫(Persian)', '布偶猫(Ragdoll)', '俄罗斯蓝猫(Russian Blue)', '暹罗猫(Siamese)', '斯芬克斯猫(Sphynx)', '美国斗牛犬
172 29
【宠物识别系统】Python+卷积神经网络算法+深度学习+人工智能+TensorFlow+图像识别
|
3天前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
18 3
|
6天前
|
安全 前端开发 数据库
Python 语言结合 Flask 框架来实现一个基础的代购商品管理、用户下单等功能的简易系统
这是一个使用 Python 和 Flask 框架实现的简易代购系统示例,涵盖商品管理、用户注册登录、订单创建及查看等功能。通过 SQLAlchemy 进行数据库操作,支持添加商品、展示详情、库存管理等。用户可注册登录并下单,系统会检查库存并记录订单。此代码仅为参考,实际应用需进一步完善,如增强安全性、集成支付接口、优化界面等。
|
15天前
|
存储 算法 Python
文件管理系统中基于 Python 语言的二叉树查找算法探秘
在数字化时代,文件管理系统至关重要。本文探讨了二叉树查找算法在文件管理中的应用,并通过Python代码展示了其实现过程。二叉树是一种非线性数据结构,每个节点最多有两个子节点。通过文件名的字典序构建和查找二叉树,能高效地管理和检索文件。相较于顺序查找,二叉树查找每次比较可排除一半子树,极大提升了查找效率,尤其适用于海量文件管理。Python代码示例包括定义节点类、插入和查找函数,展示了如何快速定位目标文件。二叉树查找算法为文件管理系统的优化提供了有效途径。
47 5
|
1月前
|
机器学习/深度学习 算法 前端开发
基于Python深度学习的果蔬识别系统实现
果蔬识别系统,主要开发语言为Python,基于TensorFlow搭建ResNet卷积神经网络算法模型,通过对12种常见的果蔬('土豆', '圣女果', '大白菜', '大葱', '梨', '胡萝卜', '芒果', '苹果', '西红柿', '韭菜', '香蕉', '黄瓜')图像数据集进行训练,最后得到一个识别精度较高的模型文件。再基于Django框架搭建Web网页端可视化操作界面,以下为项目实现介绍。
42 4
基于Python深度学习的果蔬识别系统实现
|
2月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
213 45
下一篇
开通oss服务