From 55094f77d4dcb04c46ec0bf86e0d58d93da2e358 Mon Sep 17 00:00:00 2001 From: 13507605001 Date: Fri, 6 Jan 2023 09:04:00 +0800 Subject: [PATCH] =?UTF-8?q?=E7=94=B3=E8=B4=AD=E7=9B=B8=E5=85=B3=E6=8E=A5?= =?UTF-8?q?=E5=8F=A3=E6=9B=B4=E6=96=B0;=20=E6=B3=A8=E9=87=8A=E6=B7=BB?= =?UTF-8?q?=E5=8A=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Common/report_shen_gou.py | 216 ++++++++++++++++++++++++++++++++ README.md | 27 ++++ apps/client/views.py | 50 +++++++- apps/drug/views.py | 2 +- apps/drug_template/views.py | 2 +- apps/report/utils_base.py | 5 +- apps/shengou/views.py | 136 ++++++++++++++++++++ apps/user/views.py | 2 +- config/server.py | 3 + db_logic/client_cell.py | 15 +++ db_logic/medicament.py | 91 +++++++++++--- db_logic/medicament_shengou.py | 37 ++++++ db_logic/user_apply.py | 15 +-- db_logic/user_temporary_auth.py | 1 + db_logic/variety.py | 16 +++ models/client_models.py | 2 + models/medicament_models.py | 53 ++++++++ report_a.py | 203 ++++++++++++++++++++++++++++++ 18 files changed, 846 insertions(+), 30 deletions(-) create mode 100644 Common/report_shen_gou.py create mode 100644 apps/shengou/views.py create mode 100644 db_logic/medicament_shengou.py create mode 100644 db_logic/variety.py create mode 100644 report_a.py diff --git a/Common/report_shen_gou.py b/Common/report_shen_gou.py new file mode 100644 index 0000000..a61362e --- /dev/null +++ b/Common/report_shen_gou.py @@ -0,0 +1,216 @@ +#!/usr/bin/env python +# -*- encoding: utf-8 -*- +''' +@Date:2022/08/27 11:05:06 +''' +import sys +sys.path.append('.') +import string +import os +import datetime +from openpyxl.workbook import Workbook +from openpyxl.styles import Alignment, Side, Border, Font, PatternFill + +class ReportData: + def __init__(self): + + # 新建一个workbook + self.wb = Workbook() + # 定义设置样式 + self.a = 0 + self.key_list = [ + "remark7", "remark8", "category", "remark9", + "name", "english_name","purity","cas_number","standard_code", + "unit_code","speci","net_weight_unit", "export_count","remark6", + "production_date", "shelf_life", "expiration_date", + "price", "is_supervise", "remain", "manufacturer", + "storage_condition", "remark10" + ] + self.finds_name = [ + "申购单编号","采购单编号", "药剂类别", "所属项目", "药剂名称", "英文名称", "纯度等级", "CAS码", "批号", "编号", "规格", "规格单位", "导入数量", + "导入单位", "生产日期", "保质期(天)", "到期日期", "价格(元)", "重点监管", "预估质量(g/ml)", "生产厂商", "储存条件", "包装是否完好、标签是否清晰" + ] + + def set_style(self, title='sheet1'): + # 如果是第一次调用则删除默认创建的sheet表 + if self.a == 0: + self.wb.remove(self.wb['Sheet']) + self.a += 1 + # 创建第几个sheet + self.ws = self.wb.create_sheet() + # 设置sheet的标题 + self.ws.title = title + # 生成ascii_uppercase生成所有大写字母 + self.upper_string = string.ascii_uppercase + # 水平对齐, 居中对齐 + self.alignment_style = Alignment( + horizontal='center', vertical='center') + # 定义字体 + self.font_size = Font(size=9) + for col in self.upper_string: + self.ws.column_dimensions[col].width = 10 + + # 创建第三行, 需要传入一个列表用来写入单元格的值 + def create_row3(self, data_list): + for data in range(1, len(data_list) + 1): + # 第三行写入值 + self.ws.cell(row=1, column=data).value = data_list[data - 1] + + # 创建多行固定样式 start_row从第几行开始有规律 传入一个数据库获取的列表对象的值, 传入一个数据对象keys列表 + def create_multiple_rows(self, start_row, data_list, keys_list): + # 从第4行创建 + for row_number in range(start_row, len(data_list) + start_row): + # 设置每一行的行高 + # self.ws.row_dimensions[row_number].height = 18 + # 遍历每一个对象的长度 + col_ = 1 + for key_ in keys_list: + # 写入值 + try: + value = data_list[row_number - start_row][key_] + except: + value = "" + try: + value = int(value) + self.ws.cell(row=row_number, column=col_).number_format = '0' + except: + pass + self.ws.cell(row=row_number, column=col_).value = value + col_ += 1 + + # 保存文件 + def save(self, file_path): + self.wb.save('{}.xlsx'.format(file_path)) + self.close() + + # 关闭文件 + def close(self): + self.wb.close() + + # 替换空白 + def replace_space(self, length): + self.max_lines = self.ws.max_row + upper_letter_str = string.ascii_uppercase[:length] + for upper_letter in upper_letter_str: + for row_ in range(1, self.max_lines + 1): + b = self.ws[upper_letter + str(row_)].value + # print(b) + if not b: + self.ws[upper_letter + str(row_)].value = 'null' + + # 编辑excel表格中列药剂状态1 2 3 替换为在库 出库 空瓶 + def editor_status(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '在库' + elif b == 2: + self.ws[col_ + str(row_)].value = '出库' + elif b == 3: + self.ws[col_ + str(row_)].value = '空瓶' + + # 编辑药剂重点监管列为1 0 替换为是 否 + def editor_isSupervise(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '是' + elif b == 0: + self.ws[col_ + str(row_)].value = '否' + + # 编辑操作类型 1 2 3 入库 领用 归还 + def editor_RecordType(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '入库' + elif b == 2: + self.ws[col_ + str(row_)].value = '领用' + elif b == 3: + self.ws[col_ + str(row_)].value = '归还' + + # 替换sqlAlchemy时间格式 + def editor_time(self, keys_list, params): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + col_ = string.ascii_uppercase[keys_list.index(params)] + b = self.ws[col_ + str(row_)].value + if b: + if len(b) == 19: + self.ws[col_ + str(row_)].value = b.replace('T', ' ') + else: + self.ws[col_ + str(row_)].value = "/" + + # 编辑用户管理列为1 0 替换为正常 禁用 + def editor_user_status(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '正常' + elif b == 0: + self.ws[col_ + str(row_)].value = '禁用' + + # 构建文件内容 + def build_file(self, data_list): + # data_list = kwargs.pop("data_list") + key_list = self.key_list + finds_name = self.finds_name + self.set_style(title="Sheet") + self.create_row3(finds_name) + self.create_multiple_rows(2, data_list, key_list) + for i in key_list: + if "date" in i: + self.editor_time(key_list, i) + if "status" in i: + self.editor_status(string.ascii_uppercase[key_list.index(i)]) + if "is_supervise" in i: + self.editor_isSupervise(string.ascii_uppercase[key_list.index(i)]) + if "record_type" == i: + self.editor_RecordType( + string.ascii_uppercase[key_list.index(i)]) + return self + + # 下载文件 + + @staticmethod + def download_excel(filename, chunk_size=512): + try: + f = open(filename, 'rb') + except: + return + while True: + c = f.read(chunk_size) + if c: + yield c + else: + f.close() + os.remove(filename) + break + +# if __name__ == '__main__': +# obj = ReportData() +# obj.build_file(data_list=[{"name":"测试试剂123", "shelf_life":5}]) +# obj.save("测试表1") + # data_dict = { + # "data_list":[ + # {"name": "申购单编号", "purity":"11~15%", "export_count":"2", "production_date":"2023/01/01", "shelf_life": '5'} + # ], + # "key_list": [ + # "remark7", "remark8", "category", "remark9", + # "name", "english_name","purity","cas_number","standard_code", + # "unit_code","speci","net_weight_unit", "export_count","remark6", + # "production_date", "shelf_life", "expiration_date", + # "price", "is_supervise", "remain", "manufacturer", + # "storage_condition", "remark10" + # ], + # "finds_name": [ + # "申购单编号","采购单编号", "药剂类别", "所属项目", "药剂名称", "英文名称", "纯度等级", "CAS码", "批号", "编号", "规格", "规格单位", "导入数量", + # "导入单位", "生产日期", "保质期(天)", "到期日期", "价格(元)", "重点监管", "预估质量(g/ml)", "生产厂商", "储存条件", "包装是否完好、标签是否清晰" + # ], + # } + # obj = obj.build_file(**data_dict) + # obj.save("测试表") \ No newline at end of file diff --git a/README.md b/README.md index c53cc58..953125b 100644 --- a/README.md +++ b/README.md @@ -24,3 +24,30 @@ client_id bar_code status 返回类型{"data":"", "msg":"修改成功", "status":0} + + +申购相关接口 +http://127.0.0.1:9001/api/shengou +/get_list +page +page_size + + +/add +use_doc 申请描述 +use_content 申请详情 + +/update +id 申请单id +use_content 申请详情 + +/solve +id 申请单id +result 驳回 +information 驳回原因 + + + +# 下载接口,可参考报表下载接口 +/dowload +id 申请id \ No newline at end of file diff --git a/apps/client/views.py b/apps/client/views.py index 276b519..2a30fe9 100644 --- a/apps/client/views.py +++ b/apps/client/views.py @@ -3,6 +3,7 @@ ''' @Date:2022/07/29 09:03:39 ''' +import json from flask import Blueprint, jsonify, request from sqlalchemy import and_ from Common.Utils import Utils, PageParam @@ -25,7 +26,7 @@ from models.humiture_models import EntityHumitureRecord client_router = Blueprint("client", __name__) -# 查看client列表 +# 查看client列表全部不分页 @client_router.route("/client_list", methods=["POST"]) @token_auth.login_required def get_client_list(): @@ -35,7 +36,7 @@ def get_client_list(): return jsonify(Utils.true_return(data={"data_list": data_list})) -# 查看列表 +# 查看列表分页 @client_router.route("/get_list", methods=["GET","POST"]) @token_auth.login_required def getclient_list(): @@ -66,6 +67,8 @@ def client_add_update(): ) if obj: for i in finds_list: + if i == "layer_num": + continue va = request.values.get(i) if va: setattr(client_obj, i, va) @@ -74,11 +77,17 @@ def client_add_update(): else: return jsonify(Utils.false_return(msg="柜体信息有误")) else: + client_id = Utils.UUID() client_obj = EntityClient() for i in finds_list: va = request.values.get(i) if va: setattr(client_obj, i, va) + # 添加柜子信息 + setattr(client_obj, "client_id", client_id) + # 添加柜子数量 + layer_num = request.values.get("layer_num") + BllClientCell().create_cell_layer(client_id, layer_num) BllClient().insert(client_obj) return jsonify(Utils.true_return(msg="添加成功")) @@ -150,7 +159,7 @@ def client_del(): # rms_medicament_extend,rms_medicament, rms_humiture_record # 清空指定柜体需删除 # rms_medicament_template,rms_medicament_record,rms_medicament, rms_humiture_record - +# 清空柜体 @client_router.route("/client_empty", methods=["POST"]) @token_auth.login_required def client_empty(): @@ -309,4 +318,37 @@ def client_user_ban_relieve(): if data: return jsonify(Utils.true_return()) else: - return jsonify(Utils.false_return()) \ No newline at end of file + return jsonify(Utils.false_return()) + + +# 获取已创建的位置数据 +@client_router.route("/get_client_place", methods=["POST"]) +@token_auth.login_required +def get_client_place_list(): + func_type = request.values.get("func_type") + data = BllMedicament().execute( + f"select DISTINCT place as `value` from rms_client where place is not null and place != '' and func_type='{func_type}'" + ).fetchall() + return jsonify(Utils.true_return(data=Utils.msyql_table_model(data))) + +# 获取柜子层列表 +@client_router.route("/get_client_layer", methods=["POST"]) +@token_auth.login_required +def get_client_layer_list(): + client_id = request.values.get("client_id") + data = BllClientCell().execute(f"select * from rms_client_cell where client_id='{client_id}'").fetchall() + return jsonify(Utils.true_return(data=Utils.msyql_table_model(data))) + +# 修改柜子层存放试剂数量 +@client_router.route("/update_client_storage_quantity", methods=["POST"]) +@token_auth.login_required +def update_storage_quantity(): + data_info = request.values.get("data_info") + data_dict = json.loads(data_info) + obj = BllClientCell() + for k,v in data_dict.items(): + obj_find = obj.findEntity(EntityClientCell.id == k) + if obj_find: + obj_find.storage_quantity = int(v) + obj.update(obj_find) + return jsonify(Utils.true_return()) \ No newline at end of file diff --git a/apps/drug/views.py b/apps/drug/views.py index d3a4c0c..85ca0e6 100644 --- a/apps/drug/views.py +++ b/apps/drug/views.py @@ -261,7 +261,7 @@ def drug_set_empty_bottle(): else: return jsonify(Utils.false_return(msg="试剂id有误")) - +# 修改试剂余量 @drug_router.route("/update_drug_remain", methods=["GET", "POST"]) @token_auth.login_required def update_drug_remain(): diff --git a/apps/drug_template/views.py b/apps/drug_template/views.py index 2c0e84a..a7fe288 100644 --- a/apps/drug_template/views.py +++ b/apps/drug_template/views.py @@ -326,7 +326,7 @@ def get_file_list(): return jsonify(Utils.true_return(data=data_file_list)) # return jsonify(Utils.true_return(data=os.listdir(file_path))) - +# 根据模板id打印标签 @tmp_router.route("/pring_bar_code", methods=["POST"]) @token_auth.login_required def print_code_data(): diff --git a/apps/report/utils_base.py b/apps/report/utils_base.py index 1d3171c..bb62407 100644 --- a/apps/report/utils_base.py +++ b/apps/report/utils_base.py @@ -12,10 +12,11 @@ from Common.report_excel_new import ReportData as NewReportData from Common.Utils import Utils from apps.report.dows_utils import dows_flie +# 定义报表下载字段-表字段对应 def get_finds_list(tp): dic = { # put_in_user_name,category,expiration_date - "1": ["name", "cas_number", "speci", "purity", "count_number", "sum_remain", "manufacturer", "category", "put_in_user_name", "expiration_date"], + "1": ["name", "cas_number", "speci", "purity", "count_number", "manufacturer", "category", "put_in_user_name", "expiration_date"], "2": ['name', 'manufacturer', 'distributor', 'purity', 'cas_number', 'speci', 'remain', 'net_weight', 'net_weight_unit', 'price', 'production_date', 'expiration_date', 'shelf_life', 'unit_code', 'remark2', 'category', 'standard_code', 'storage_condition', 'remark9', 'put_in_user_name', 'put_in_date'], # "2": ["name", "bar_code", "purity", "speci", "manufacturer", "count_number", "status", "put_in_date", "put_in_user_name", "client_name"], "3": ['name', 'unit_code', 'bar_code', 'remark2', 'speci', 'remain', 'purity', 'cas_number', 'production_date', 'expiration_date', 'shelf_life', 'price', 'net_weight', 'net_weight_unit', 'put_in_date', 'manufacturer', 'storage_condition', 'remark9', 'category', 'standard_code', 'put_in_user_name', 'status', 'by_user_name', 'client_name'], @@ -34,6 +35,7 @@ def get_finds_list(tp): } return dic.get(str(tp)) +# 报表字段,中文展示字段 def get_finds_name_list(tp): dic = { "1": ["试剂名称", "CAS码", "规格", "纯度", "在库剩余数量(瓶)", "生产厂家", "试剂分类(易制毒、易制爆、剧毒品)", "入库人", "过期时间"], @@ -55,6 +57,7 @@ def get_finds_name_list(tp): return dic.get(str(tp)) +# 下载方法 def download_file(file_name, data_list, tp): try: file_path = os.path.join(os.getcwd(), "report_file") diff --git a/apps/shengou/views.py b/apps/shengou/views.py new file mode 100644 index 0000000..c52a543 --- /dev/null +++ b/apps/shengou/views.py @@ -0,0 +1,136 @@ +#!/usr/bin/env python +# -*- encoding: utf-8 -*- +''' +@Date: 2023/01/05 14:10:45 +''' +import sys +sys.path.append('.') +import os +import json +from flask import Blueprint, request, jsonify, g +from sqlalchemy import and_, or_ +from db_logic.medicament_shengou import BllMedicamntShenGou +from models.medicament_models import EntityMedicamntShenGou +from Common.report_shen_gou import ReportData +from db_logic.user import BllUser +from Common.Utils import Utils, PageParam +from Common.auth import token_auth +from apps.report.dows_utils import dows_flie + +shengou_bp = Blueprint("shengou", __name__) + +# 展示列表,根据用户角色是否展示全部 +@shengou_bp.route("/get_list", methods=["POST"]) +@token_auth.login_required +def get_shengou_list(): + user = g.current_user + page = request.values.get("page") + page_size = request.values.get("page_size") + page_param = PageParam(int(page), int(page_size)) + data = BllMedicamntShenGou().get_list(user=user, page_param=page_param) + user_list = BllUser().findList() + user_dict = {} + for i in user_list: + user_dict[i.user_id] = i.real_name + data_list = [] + for i in data: + i_dict = dict(i._mapping) + i_dict['user_name'] = user_dict.get(i_dict["user_id"]) + i_dict["solve_user_name"] = user_dict.get(i_dict["solve_user_id"], '') + i_dict["solve_user_pt_name"] = user_dict.get(i_dict["solve_user_id_pt"], '') + data_list.append(i_dict) + return jsonify(Utils.true_return(data= {"data_list":data_list, "total_count": page_param.totalRecords})) + + +# 创建申请记录 +@shengou_bp.route("/add", methods=["POST"]) +@token_auth.login_required +def add_drug_shengou(): + func_type = request.values.get("func_type") + use_doc = request.values.get("use_doc") + use_content = request.values.get("use_content") + + if not use_content: + return jsonify(Utils.false_return(msg='内容为空,无需提交')) + obj = EntityMedicamntShenGou( + user_id = g.current_user.user_id, + create_date = Utils.get_str_datetime(), + is_solve = 0, + use_content = use_content, + func_type=func_type, + use_doc=use_doc + ) + BllMedicamntShenGou().insert(obj) + return jsonify(Utils.true_return()) + +# 修改个人申请 +@shengou_bp.route("/update", methods=["POST"]) +@token_auth.login_required +def update_shengou(): + shengou_id = request.values.get("id") + use_content = request.values.get("use_content") + if not use_content: + return jsonify(Utils.false_return(msg='内容为空,无需提交')) + user = g.current_user + user_apply_obj = BllMedicamntShenGou().findEntity( + and_( + EntityMedicamntShenGou.id == shengou_id, + EntityMedicamntShenGou.user_id == user.user_id + ) + ) + if not user_apply_obj: + return jsonify(Utils.false_return(msg="只能修改自己的申请!")) + user_apply_obj.use_content=use_content + BllMedicamntShenGou().update(user_apply_obj) + return jsonify(Utils.true_return()) + + +# 处理消息 +@shengou_bp.route("/solve", methods=["POST"]) +@token_auth.login_required +def solve_shengou(): + shengou_id =request.values.get("id") + user_id = g.current_user.user_id + obj = BllMedicamntShenGou().findEntity(EntityMedicamntShenGou.id == shengou_id) + if obj.is_solve == 1: + return jsonify(Utils.false_return(msg="已受理,无需重复受理")) + if str(request.values.get('result')) == "0": + obj.information = request.values.get("information") + obj.is_solve = 2 + else: + if not obj.solve_user_id: + obj.solve_user_id = user_id + else: + if user_id == obj.solve_user_id: + return jsonify(Utils.false_return(msg="不能位同一人审批")) + obj.solve_user_id_pt=user_id + obj.is_solve = 1 + obj.solve_date = Utils.get_str_datetime() + BllMedicamntShenGou().update(obj) + return jsonify(Utils.true_return()) + +# 导出申购单 +@shengou_bp.route("/dowload", methods=["GET", "POST"]) +@token_auth.login_required +def dowload_shengou(): + shengou_id = request.values.get("id") + obj = BllMedicamntShenGou().findEntity(EntityMedicamntShenGou.id == shengou_id) + if obj and obj.is_solve == 1: + try: + file_path = os.path.join(os.getcwd(), "report_file") + if not os.path.exists(file_path): + os.makedirs(file_path) + obj_report = ReportData() + obj = obj_report.build_file(json.loads(obj.use_content)) + rsp_file_name = f"tem_申购单_{Utils.get_file_name_datetime()}" + obj.save(os.path.join(file_path, rsp_file_name)) + # u_path = Utils.getUDiskPath() + # if u_path: + # obj.save(os.path.join(u_path, rsp_file_name)) + rep = dows_flie(file_path, rsp_file_name) + return rep + # return jsonify(Utils.true_return()) + except Exception as error: + print(error) + return jsonify(Utils.false_return(msg=f"导出错误:{error}")) + return jsonify(Utils.false_return(msg="申购单导出错误")) diff --git a/apps/user/views.py b/apps/user/views.py index b3a2d07..9b00faa 100644 --- a/apps/user/views.py +++ b/apps/user/views.py @@ -14,7 +14,7 @@ from models.user_models import EntityUser user_router = Blueprint('user', __name__) - +# 登录 @user_router.route("/login", methods=["POST"]) # @token_auth.login_required def user_login(): diff --git a/config/server.py b/config/server.py index 729a36e..bc84c93 100644 --- a/config/server.py +++ b/config/server.py @@ -74,6 +74,7 @@ def register_blueprints(app: New_flask): from apps.drug_form.views import drug_form_router from apps.stock_record.views import stock_router from apps.temporary_auth.views import temporary_bp + from apps.shengou.views import shengou_bp # 主概览相关 app.register_blueprint(home_router, url_prefix="/api/home") @@ -101,6 +102,8 @@ def register_blueprints(app: New_flask): app.register_blueprint(stock_router, url_prefix="/api/stock") # 申请 app.register_blueprint(temporary_bp, url_prefix="/api/temporary_auth") + # 申购 + app.register_blueprint(shengou_bp, url_prefix="/api/shengou") def create_app(): app = Flask(__name__) diff --git a/db_logic/client_cell.py b/db_logic/client_cell.py index 7992c95..f9868b4 100644 --- a/db_logic/client_cell.py +++ b/db_logic/client_cell.py @@ -33,6 +33,21 @@ class BllClientCell(Repository): page_sql = Utils.sql_paging_assemble(sql_all, page_param) return self.execute(page_sql).fetchall() + def create_cell_layer(self, client_id, layer_num): + + obj_list = [] + for i in range(1, int(layer_num)+1): + obj_list.append( + EntityClientCell( + cell_code = i, + client_id=client_id, + cell_speci=f"{i}号格子", + storage_quantity=50 + ) + ) + self.insert_many(obj_list) + return True + # 插入测试数据 def inster_test_data(self): client_id = '1c39cb24-07f8-11ed-abd4-f47b094925e1' diff --git a/db_logic/medicament.py b/db_logic/medicament.py index 7f5c431..addaa11 100644 --- a/db_logic/medicament.py +++ b/db_logic/medicament.py @@ -8,10 +8,11 @@ sys.path.append('.') from sqlalchemy import distinct, or_, and_, desc, asc from sqlalchemy.sql import func from db_logic.db_base import Repository -from models.medicament_models import EntityMedicament, EntityMedicamentRecord, EntityMedicamentTemplate +from models.medicament_models import EntityMedicament, EntityMedicamentRecord, EntityMedicamentTemplate, EntityVariety from models.client_models import EntityClient from models.user_models import EntityUser from db_logic.meidcament_variety import BllMedicamentVariety +from db_logic.variety import BllVariety from Common.Utils import Utils, DrugStatus, DrugRecordType @@ -41,25 +42,42 @@ class BllMedicament(Repository): # 获取可入库层数据 def get_drug_save_db_info(self, drug_name, func_type): - sql_all = f""" + # sql_all = f""" - select name, IFNULL(num,0) number, c.client_name, c.client_id, cell_code, cell_speci from ( - select cell_code, a.client_id, cell_speci, client_name from ( - select * from rms_client_cell - ) a LEFT JOIN( - select client_id, client_name from rms_client - ) b on a.client_id = b.client_id - ) c LEFT JOIN( - select name, client_id, flow_position_code, count(*) num - from rms_medicament where `name` like '%{drug_name}%' and status=1 and func_type={func_type} - GROUP BY client_id, flow_position_code - ) d on c.client_id=d.client_id and c.cell_code=d.flow_position_code + # select name, IFNULL(num,0) number, c.client_name, c.client_id, cell_code, cell_speci from ( + # select cell_code, a.client_id, cell_speci, client_name from ( + # select * from rms_client_cell + # ) a LEFT JOIN( + # select client_id, client_name from rms_client + # ) b on a.client_id = b.client_id + # ) c LEFT JOIN( + # select name, client_id, flow_position_code, count(*) num + # from rms_medicament where `name` like '%{drug_name}%' and status=1 and func_type={func_type} + # GROUP BY client_id, flow_position_code + # ) d on c.client_id=d.client_id and c.cell_code=d.flow_position_code - HAVING number < 40 + # HAVING number < 40 + # """ + sql_all = f""" + select c.*, d.client_name + from ( + select a.cell_code,a.client_id, a.cell_speci, IFNULL(a.storage_quantity,0) storage_quantity, count(b.name) num, IFNULL(GROUP_CONCAT(b.name),'') name_json + from (select * from rms_client_cell) a + LEFT JOIN (select * from rms_medicament) b on a.client_id=b.client_id and a.cell_speci=b.flow_position_code + GROUP BY a.id + ) c LEFT JOIN (select * from rms_client where func_type={func_type}) d on c.client_id=d.client_id + where d.client_name is not null + """ data = self.execute(sql_all).fetchall() + data_list = [] data_dict = {} for i in data: + if int(i.num) >= int(i.storage_quantity): + continue + # 处理当前试剂是否与试剂柜内的试剂冲突,当前试剂名称,数据库内当前层的试剂列表 + # if drug_name in i.name_json.split(","): + # pass if i.client_id in data_dict.keys(): data_dict[i.client_id]["client_cell"].append(i.cell_speci) else: @@ -69,8 +87,22 @@ class BllMedicament(Repository): "client_cell": [i.cell_speci] } data_dict[i.client_id] = client_dict + # data_dict = {} + # for i in data: + # if i.client_id in data_dict.keys(): + # data_dict[i.client_id]["client_cell"].append(i.cell_speci) + # else: + # client_dict = { + # "client_id": i.client_id, + # "client_name": i.client_name, + # "client_cell": [i.cell_speci] + # } + # data_dict[i.client_id] = client_dict data_list = [] for k,v in data_dict.items(): + DrugSetPotionStorageIn = self.getDrugSetPotionStorageIn(drug_name, k) + if DrugSetPotionStorageIn[0]: + v["conflict"] = DrugSetPotionStorageIn[1] data_list.append(v) return data_list @@ -680,6 +712,33 @@ class BllMedicament(Repository): sql_all = Utils.sql_paging_assemble(sql_all, page_param) return self.execute(sql_all).fetchall() + + + + def getDrugSetPotionStorageIn(self,name,clientId=""): + #print('clientId',clientId) + allLabelSqlStr="SELECT group_concat(remark3) AS allLabels FROM( SELECT DISTINCT b.remark3 FROM rms_medicament as a LEFT JOIN rms_variety as b ON a.`name`=b.`name` WHERE b.purity='权限设置' and a.status=1 AND a.client_id='"+clientId+"')T" + allLabels= self.execute(allLabelSqlStr).fetchone()[0] + #print('allLabels:',allLabels) + if allLabels: + allLabelList=allLabels.split(',') + drugVarietyEntity= BllVariety().findEntity(and_(EntityVariety.name==name,EntityVariety.purity=='权限设置')) + #print('drugVarietyEntity.Remark3:',drugVarietyEntity.Remark3) + if drugVarietyEntity: + for sx in drugVarietyEntity.remark3.split(','): + #print('sx:',sx) + drugLabelsSqlstr="SELECT name2 AS reagent,relation FROM rms_medicament_relation a WHERE a.name1='"+sx+"' UNION SELECT name1 AS reagent,relation FROM rms_medicament_relation a WHERE a.name2='"+sx+"'" + drugLabelList=self.execute(drugLabelsSqlstr).fetchall() + #print('drugLabelList:',drugLabelList) + for item in drugLabelList: + if(item[0] in allLabelList): + return(False,item[1]) + return(True,'') + else: + return(True,'') + else: + return(True,'') + def inster_log_shiji(self): import random name_list = ["砷", "硫酸", "氧化钠"] @@ -705,7 +764,9 @@ class BllMedicament(Repository): obj_list.append(obj) self.insert_many(obj_list) -# if __name__ == '__main__': +if __name__ == '__main__': + data = BllMedicament().getDrugSetPotionStorageIn("2-氨基苯酚", '1c39cb24-07f8-11ed-abd4-f47b094925e1') + print(data) # from db_logic.medicament import BllMedicament # from Common.Utils import PageParam # page_param = PageParam(1, 10) diff --git a/db_logic/medicament_shengou.py b/db_logic/medicament_shengou.py new file mode 100644 index 0000000..afadeb1 --- /dev/null +++ b/db_logic/medicament_shengou.py @@ -0,0 +1,37 @@ +#!/usr/bin/env python +# -*- encoding: utf-8 -*- +''' +@Date: 2023/01/05 14:09:40 +''' +import sys +sys.path.append('.') + + +from db_logic.db_base import Repository +from Common.Utils import Utils +from models.medicament_models import EntityMedicamntShenGou + + + +class BllMedicamntShenGou(Repository): + def __init__(self, entityType=EntityMedicamntShenGou): + return super().__init__(entityType) + + def get_list(self, user, page_param): + filter_base = "" + if "管理员" not in user.role_name: + filter_base += f" user_id='{user.user_id}'" + if filter_base: + filter_base = f" where {filter_base}" + + sql_all = f""" + select * from rms_medicamnt_shengou {filter_base} + """ + try: + count_number = self.execute(f"select count(*) num from ({sql_all})a ").fetchone().num + except Exception: + count_number = 0 + if page_param: + page_param.totalRecords = count_number + sql_all = Utils.sql_paging_assemble(sql_all, page_param) + return self.execute(sql_all).fetchall() diff --git a/db_logic/user_apply.py b/db_logic/user_apply.py index 2cf05d3..a873565 100644 --- a/db_logic/user_apply.py +++ b/db_logic/user_apply.py @@ -16,6 +16,7 @@ class BllUserApply(Repository): def __init__(self, entityType=EntityUserApply): super().__init__(entityType) + # 根据用户角色进行列表返回 def get_list_info(self, func_type, page_param, user): fileter_base = "" # if client_id: @@ -71,7 +72,8 @@ class BllUserApply(Repository): for j in range(len(use_content)): con_info = use_content[j] if con_info["client_id"] == client_id: - if con_info["name"] == drug_info.name and con_info["purity"] == drug_info.purity and con_info["speci"] == drug_info.speci: + # if con_info["name"] == drug_info.name and con_info["purity"] == drug_info.purity and con_info["speci"] == drug_info.speci: + if con_info["medicament_id"] == drug_info.medicament_id: if not con_info.get("use_num"): con_info["use_num"] = 0 if int(con_info["use_num"]) < int(con_info["num"]): @@ -80,7 +82,8 @@ class BllUserApply(Repository): obj = self.findEntity(self.entityType.id == d.id) obj.use_content = json.dumps(use_content) self.update(obj) - + + # 获取待领用列表 def get_stay_use_list(self, client_id, user): sql_all = f""" select * from rms_user_apply @@ -98,9 +101,7 @@ class BllUserApply(Repository): j = use_content[j_index] if j["client_id"] != client_id: continue - if j.get("use_num") != 0: - n = int(j.get("num")) - int(j.get("use_num")) - if n > 0: - j["stay_use_num"] = n - data_list.append(j) + # if j.get("use_num") != 0: + j["stay_use_num"] = j.get("use_num") + data_list.append(j) return data_list diff --git a/db_logic/user_temporary_auth.py b/db_logic/user_temporary_auth.py index 2c216a9..be96397 100644 --- a/db_logic/user_temporary_auth.py +++ b/db_logic/user_temporary_auth.py @@ -20,6 +20,7 @@ class BllUserTemporaryAuth(Repository): def __init__(self, entityType=EntityUserTemporaryAuth): super().__init__(entityType) + # 创建临时权限 def create_temporary_auth(self, user_ids, auth_type, t=None): # try: # client_code = BllClient().findEntity(EntityClient.client_id == client_id).client_code diff --git a/db_logic/variety.py b/db_logic/variety.py new file mode 100644 index 0000000..ad56844 --- /dev/null +++ b/db_logic/variety.py @@ -0,0 +1,16 @@ +#!/usr/bin/env python +# -*- encoding: utf-8 -*- +''' +@Date:2022/07/19 09:43:08 +''' +import sys +sys.path.append(".") +from db_logic.db_base import Repository +from models.medicament_models import EntityVariety + + +#药剂品种业务逻辑类 +class BllVariety(Repository): + def __init__(self, entityType=EntityVariety): + return super().__init__(entityType) + diff --git a/models/client_models.py b/models/client_models.py index d29e8e9..6fedfbc 100644 --- a/models/client_models.py +++ b/models/client_models.py @@ -53,6 +53,7 @@ class EntityClient(Base): description = Column(String(200), comment='备注') # 备注 is_add = Column(Integer, comment='是否添加', default=0) func_type = Column(Integer, comment='试剂柜类型', default=0) + layer_num = Column(Integer, comment='柜子层数', default=6) class EntityClientCellUser(Base): __tablename__ = "rms_client_cell_user" @@ -113,6 +114,7 @@ class EntityClientCell(Base): cell_code = Column(String(50), comment="抽屉码") client_id = Column(String(50), comment="终端id") cell_speci = Column(String(50), comment="单元格") + storage_quantity = Column(Integer, comment="存放试剂数量", default=50) if __name__ == '__main__': diff --git a/models/medicament_models.py b/models/medicament_models.py index ef8c501..25a3698 100644 --- a/models/medicament_models.py +++ b/models/medicament_models.py @@ -328,6 +328,59 @@ class EntityMedicamentRelationImage(Base): +class EntityVariety(Base): + __tablename__ = "rms_variety" + __table_args__ = ( + { + "comment": "药剂类型实体类" + } + ) + variety_id = Column( + String(50), primary_key=True, comment="类型ID", default=get_uuid) + customer_id = Column(String(50), comment="客户ID") + cas_number = Column(String(50), comment="药剂cas码") + name = Column(String(50), comment="药剂名称") + english_name = Column(String(50), comment="英文名称") + purity = Column(String(50), comment="纯度") + is_supervise = Column(Integer, comment="是否监管", default=0) + inventory_warning_value = Column(Integer, comment="库存预警量") + shelf_life_warning_value = Column(Integer, comment="保质期到期提前预警天数") + use_days_warning_value = Column(Integer, comment="领用超期预警天数") + is_weigh = Column(Integer, comment="是否称重") + empty_count = Column(Integer, comment="空瓶数量") + use_count = Column(Integer, comment="当前领用数量") + normal_count = Column(Integer, comment="在库数量") + total_count = Column(Integer, comment="总数量") + remark1 = Column(String(50), comment='扩展字段1') + remark2 = Column(String(50), comment='扩展字段2') + remark3 = Column(String(50), comment='扩展字段3') + create_date = Column(String(50), comment="创建日期") + create_user_id = Column(String(50), comment="创建用户ID") + create_user_name = Column(String(50), comment="创建用户名称") + modify_date = Column(String(50), comment="修改时间") + modify_user_id = Column(String(50), comment="修改用户ID") + modify_user_name = Column(String(50), comment="修改用户名称") + is_add = Column(Integer, comment="", default=0) + +class EntityMedicamntShenGou(Base): + __tablename__ = "rms_medicamnt_shengou" + __table_args__ = ( + { + "comment": "试剂申购申请表" + } + ) + id = Column(String(50), primary_key=True, comment="id", default=get_uuid) + user_id = Column(String(50), comment="用户id") + create_date = Column(String(50), comment="申请时间") + use_content = Column(Text, comment="领用详情") + is_solve = Column(Integer, comment="是否处理", default=0) + solve_date = Column(String(50), comment="受理时间") + solve_user_id = Column(String(50), comment="受理人") + solve_user_id_pt = Column(String(50), comment="受理人") + func_type = Column(Integer, comment="类型") + use_doc = Column(Text, comment="类型") + information = Column(Text, comment="驳回原因") + if __name__ == '__main__': drug_info = {} user_info = {} diff --git a/report_a.py b/report_a.py new file mode 100644 index 0000000..4361370 --- /dev/null +++ b/report_a.py @@ -0,0 +1,203 @@ +#!/usr/bin/env python +# -*- encoding: utf-8 -*- +''' +@Date:2022/08/27 11:05:06 +''' +import sys +from types import CellType +sys.path.append('.') +import string +import os +import datetime +from openpyxl.workbook import Workbook +from openpyxl.styles import Alignment, Side, Border, Font, PatternFill + +class ReportData: + def __init__(self): + + # 新建一个workbook + self.wb = Workbook() + # 定义设置样式 + self.a = 0 + + def set_style(self, title='sheet1'): + # 如果是第一次调用则删除默认创建的sheet表 + if self.a == 0: + self.wb.remove(self.wb['Sheet']) + self.a += 1 + # 创建第几个sheet + self.ws = self.wb.create_sheet() + # 设置sheet的标题 + self.ws.title = title + # 生成ascii_uppercase生成所有大写字母 + self.upper_string = string.ascii_uppercase + # 水平对齐, 居中对齐 + self.alignment_style = Alignment( + horizontal='center', vertical='center') + # 定义字体 + self.font_size = Font(size=9) + for col in self.upper_string: + self.ws.column_dimensions[col].width = 10 + + # 创建第三行, 需要传入一个列表用来写入单元格的值 + def create_row3(self, data_list): + for data in range(1, len(data_list) + 1): + # 第三行写入值 + self.ws.cell(row=1, column=data).value = data_list[data - 1] + + # 创建多行固定样式 start_row从第几行开始有规律 传入一个数据库获取的列表对象的值, 传入一个数据对象keys列表 + def create_multiple_rows(self, start_row, data_list, keys_list): + # 从第4行创建 + for row_number in range(start_row, len(data_list) + start_row): + # 设置每一行的行高 + # self.ws.row_dimensions[row_number].height = 18 + # 遍历每一个对象的长度 + col_ = 1 + for key_ in keys_list: + # 写入值 + try: + value = data_list[row_number - start_row][key_] + except: + value = "" + try: + value = int(value) + self.ws.cell(row=row_number, column=col_).number_format = '0' + except: + pass + self.ws.cell(row=row_number, column=col_).value = value + col_ += 1 + + # 保存文件 + def save(self, file_path): + self.wb.save('{}.xlsx'.format(file_path)) + self.close() + + # 关闭文件 + def close(self): + self.wb.close() + + # 替换空白 + def replace_space(self, length): + self.max_lines = self.ws.max_row + upper_letter_str = string.ascii_uppercase[:length] + for upper_letter in upper_letter_str: + for row_ in range(1, self.max_lines + 1): + b = self.ws[upper_letter + str(row_)].value + # print(b) + if not b: + self.ws[upper_letter + str(row_)].value = 'null' + + # 编辑excel表格中列药剂状态1 2 3 替换为在库 出库 空瓶 + def editor_status(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '在库' + elif b == 2: + self.ws[col_ + str(row_)].value = '出库' + elif b == 3: + self.ws[col_ + str(row_)].value = '空瓶' + + # 编辑药剂重点监管列为1 0 替换为是 否 + def editor_isSupervise(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '是' + elif b == 0: + self.ws[col_ + str(row_)].value = '否' + + # 编辑操作类型 1 2 3 入库 领用 归还 + def editor_RecordType(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '入库' + elif b == 2: + self.ws[col_ + str(row_)].value = '领用' + elif b == 3: + self.ws[col_ + str(row_)].value = '归还' + + # 替换sqlAlchemy时间格式 + def editor_time(self, keys_list, params): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + col_ = string.ascii_uppercase[keys_list.index(params)] + b = self.ws[col_ + str(row_)].value + if b: + if len(b) == 19: + self.ws[col_ + str(row_)].value = b.replace('T', ' ') + else: + self.ws[col_ + str(row_)].value = "/" + + # 编辑用户管理列为1 0 替换为正常 禁用 + def editor_user_status(self, col_): + self.max_lines = self.ws.max_row + for row_ in range(4, self.max_lines + 1): + b = self.ws[col_ + str(row_)].value + if b == 1: + self.ws[col_ + str(row_)].value = '正常' + elif b == 0: + self.ws[col_ + str(row_)].value = '禁用' + + # 构建文件内容 + def build_file(self,**kwargs): + data_list = kwargs.pop("data_list") + key_list = kwargs.pop("key_list") + finds_name = kwargs.pop("finds_name") + self.set_style(title="Sheet") + self.create_row3(finds_name) + self.create_multiple_rows(2, data_list, key_list) + for i in key_list: + if "date" in i: + self.editor_time(key_list, i) + if "status" in i: + self.editor_status(string.ascii_uppercase[key_list.index(i)]) + if "is_supervise" in i: + self.editor_isSupervise(string.ascii_uppercase[key_list.index(i)]) + if "record_type" == i: + self.editor_RecordType( + string.ascii_uppercase[key_list.index(i)]) + return self + + # 下载文件 + + @staticmethod + def download_excel(filename, chunk_size=512): + try: + f = open(filename, 'rb') + except: + return + while True: + c = f.read(chunk_size) + if c: + yield c + else: + f.close() + os.remove(filename) + break + +if __name__ == '__main__': + obj = ReportData() + data_dict = { + "data_list":[ + {"name": "申购单编号", "purity":"11~15%", "export_count":"2", "production_date":"2023/01/01", "shelf_life": '5'} + ], + "key_list": [ + "remark7", "remark8", "category", "remark9", + "name", "english_name","purity","cas_number","standard_code", + "unit_code","speci","net_weight_unit", "export_count","remark6", + "production_date", "shelf_life", "expiration_date", + "price", "is_supervise", "remain", "manufacturer", + "storage_condition", "remark10" + ], + "finds_name": [ + "申购单编号","采购单编号", "药剂类别", "所属项目", "药剂名称", "英文名称", "纯度等级", "CAS码", "批号", "编号", "规格", "规格单位", "导入数量", + "导入单位", "生产日期", "保质期(天)", "到期日期", "价格(元)", "重点监管", "预估质量(g/ml)", "生产厂商", "储存条件", "包装是否完好、标签是否清晰" + ], + } + obj = obj.build_file(**data_dict) + obj.save("测试表") \ No newline at end of file