您的位置:首页 > 游戏 > 手游 > 中国建设银行官网网址是多少_浙江工程造价信息网_成都seo优化_今天的最新消息新闻

中国建设银行官网网址是多少_浙江工程造价信息网_成都seo优化_今天的最新消息新闻

2025/3/11 1:04:04 来源:https://blog.csdn.net/yimeixiaolangzai/article/details/145870556  浏览:    关键词:中国建设银行官网网址是多少_浙江工程造价信息网_成都seo优化_今天的最新消息新闻
中国建设银行官网网址是多少_浙江工程造价信息网_成都seo优化_今天的最新消息新闻

收藏关注不迷路!!

🌟文末获取源码+数据库🌟

感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人

文章目录
  • 摘要
  • 一、开发技术介绍
  • 二、功能介绍
  • 三、代码展示
  • 四、效果图
  • 五 、源码获取

摘要

酒店推荐系统旨在提供一个全面酒店推荐在线平台,该系统允许用户浏览不同的客房类型,并根据个人偏好和需求推荐合适的酒店客房。用户可以便捷地进行客房预订,并在抵达后简化入住登记流程。为了确保连续的住宿体验,系统还提供续订功能,让用户无需重复预订过程。退房模块使得结账过程快速而高效。用户还可以通过留言反馈功能分享他们的住宿体验,帮助其他用户做出更明智的选择,并为酒店提供宝贵的客户意见。总的来说,这个系统旨在提升用户体验,同时帮助酒店更好地理解客户需求,并优化服务质量。

系统采用基于Python语言网站开发技术设计的,结合django框架和Mysql数据库管理系统对酒店推荐相关信息进行管理。按照软件工程学理论完成各阶段设计,经过调试测试达到了管理酒店推荐的能力。满足了管理员和用户的需要。论文从系统开发过程概述、开发工具简介、系统总体设计、系统开发、软件测试等几个方面进行了介绍。最后总结了系统开发的得失。

关键词:酒店推荐;Python技术;django框架;Mysql;

一、开发技术介绍

  • Python
  • Django
  • Vue
  • MySQL
  • 协同过滤算法

二、功能介绍

根据需求说明设计系统各功能模块。采用模块化设计方法实现一个复杂结构进行简化,分成一个个小的容易解决的板块,然后再将小的板块继续分化成功能单一的更小模块。模块化设计方法使测试调试、维护更容易,减少模块间的干扰。各模块可以同时开发提高开发效率。本系统功能结构图:
在这里插入图片描述

三、代码展示

#coding:utf-8
__author__ = "ila"
import base64, copy, logging, os, sys, time, xlrd, json, datetime, configparser
from django.http import JsonResponse
from django.apps import apps
from django.db.models.aggregates import Count,Sum
from django.db.models import Case, When, IntegerField, F
from django.forms import model_to_dict
from util.CustomJSONEncoder import CustomJsonEncoder
from .models import ruzhudengji
from util.codes import *
from util.auth import Auth
from util.common import Common
import util.message as mes
from django.db import connection
import random
from django.core.mail import send_mail
from django.conf import settings
from django.shortcuts import redirect
from django.db.models import Q
from util.baidubce_api import BaiDuBce
from .config_model import configdef ruzhudengji_register(request):if request.method in ["POST", "GET"]:msg = {'code': normal_code, "msg": mes.normal_code}req_dict = request.session.get("req_dict")error = ruzhudengji.createbyreq(ruzhudengji, ruzhudengji, req_dict)if error != None:msg['code'] = crud_error_codemsg['msg'] = "用户已存在,请勿重复注册!"return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_login(request):if request.method in ["POST", "GET"]:msg = {'code': normal_code, "msg": mes.normal_code}req_dict = request.session.get("req_dict")datas = ruzhudengji.getbyparams(ruzhudengji, ruzhudengji, req_dict)if not datas:msg['code'] = password_error_codemsg['msg'] = mes.password_error_codereturn JsonResponse(msg, encoder=CustomJsonEncoder)try:__sfsh__= ruzhudengji.__sfsh__except:__sfsh__=Noneif  __sfsh__=='是':if datas[0].get('sfsh')!='是':msg['code']=other_codemsg['msg'] = "账号已锁定,请联系管理员审核!"return JsonResponse(msg, encoder=CustomJsonEncoder)req_dict['id'] = datas[0].get('id')return Auth.authenticate(Auth, ruzhudengji, req_dict)def ruzhudengji_logout(request):if request.method in ["POST", "GET"]:msg = {"msg": "登出成功","code": 0}return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_resetPass(request):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code}req_dict = request.session.get("req_dict")columns=  ruzhudengji.getallcolumn( ruzhudengji, ruzhudengji)try:__loginUserColumn__= ruzhudengji.__loginUserColumn__except:__loginUserColumn__=Noneusername=req_dict.get(list(req_dict.keys())[0])if __loginUserColumn__:username_str=__loginUserColumn__else:username_str=usernameif 'mima' in columns:password_str='mima'else:password_str='password'init_pwd = '123456'recordsParam = {}recordsParam[username_str] = req_dict.get("username")records=ruzhudengji.getbyparams(ruzhudengji, ruzhudengji, recordsParam)if len(records)<1:msg['code'] = 400msg['msg'] = '用户不存在'return JsonResponse(msg, encoder=CustomJsonEncoder)eval('''ruzhudengji.objects.filter({}='{}').update({}='{}')'''.format(username_str,username,password_str,init_pwd))return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_session(request):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code,"msg": mes.normal_code, "data": {}}req_dict={"id":request.session.get('params').get("id")}msg['data']  = ruzhudengji.getbyparams(ruzhudengji, ruzhudengji, req_dict)[0]return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_default(request):if request.method in ["POST", "GET"]:msg = {"code": normal_code,"msg": mes.normal_code, "data": {}}req_dict = request.session.get("req_dict")req_dict.update({"isdefault":"是"})data=ruzhudengji.getbyparams(ruzhudengji, ruzhudengji, req_dict)if len(data)>0:msg['data']  = data[0]else:msg['data']  = {}return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_page(request):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code,  "data":{"currPage":1,"totalPage":1,"total":1,"pageSize":10,"list":[]}}req_dict = request.session.get("req_dict")global ruzhudengji#获取全部列名columns=  ruzhudengji.getallcolumn( ruzhudengji, ruzhudengji)if "vipread" in req_dict and "vipread" not in columns:del req_dict["vipread"]#当前登录用户所在表tablename = request.session.get("tablename")#authColumn=list(__authTables__.keys())[0]#authTable=__authTables__.get(authColumn)# if authTable==tablename:#params = request.session.get("params")#req_dict[authColumn]=params.get(authColumn)'''__authSeparate__此属性为真,params添加userid,后台只查询个人数据'''try:__authSeparate__=ruzhudengji.__authSeparate__except:__authSeparate__=Noneif __authSeparate__=="是":tablename=request.session.get("tablename")if tablename!="users" and 'userid' in columns:try:req_dict['userid']=request.session.get("params").get("id")except:pass#当项目属性hasMessage为”是”,生成系统自动生成留言板的表messages,同时该表的表属性hasMessage也被设置为”是”,字段包括userid(用户id),username(用户名),content(留言内容),reply(回复)#接口page需要区分权限,普通用户查看自己的留言和回复记录,管理员查看所有的留言和回复记录try:__hasMessage__=ruzhudengji.__hasMessage__except:__hasMessage__=Noneif  __hasMessage__=="是":tablename=request.session.get("tablename")if tablename!="users":req_dict["userid"]=request.session.get("params").get("id")# 判断当前表的表属性isAdmin,为真则是管理员表# 当表属性isAdmin=”是”,刷出来的用户表也是管理员,即page和list可以查看所有人的考试记录(同时应用于其他表)__isAdmin__ = NoneallModels = apps.get_app_config('main').get_models()for m in allModels:if m.__tablename__==tablename:try:__isAdmin__ = m.__isAdmin__except:__isAdmin__ = Nonebreak# 当前表也是有管理员权限的表if  __isAdmin__ == "是" and 'ruzhudengji' != 'forum':if req_dict.get("userid") and 'ruzhudengji' != 'chat':del req_dict["userid"]else:#非管理员权限的表,判断当前表字段名是否有useridif tablename!="users" and 'ruzhudengji'[:7]!='discuss'and "userid" in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji):req_dict["userid"] = request.session.get("params").get("id")#当列属性authTable有值(某个用户表)[该列的列名必须和该用户表的登陆字段名一致],则对应的表有个隐藏属性authTable为”是”,那么该用户查看该表信息时,只能查看自己的try:__authTables__=ruzhudengji.__authTables__except:__authTables__=Noneif __authTables__!=None and  __authTables__!={} and __isAdmin__ == "是":try:del req_dict['userid']# tablename=request.session.get("tablename")# if tablename=="users":# del req_dict['userid']except:passfor authColumn,authTable in __authTables__.items():if authTable==tablename:params = request.session.get("params")req_dict[authColumn]=params.get(authColumn)username=params.get(authColumn)breakif tablename == 'yonghu':from .models import yonghureq_dict['yonghuzhanghao'] = request.session.get("params").get(yonghu.__loginUserColumn__)if 'userid' in req_dict.keys():del req_dict["userid"]q = Q()msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \msg['data']['pageSize']  =ruzhudengji.page(ruzhudengji, ruzhudengji, req_dict, request, q)return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_autoSort(request):'''.智能推荐功能(表属性:[intelRecom(是/否)],新增clicktime[前端不显示该字段]字段(调用info/detail接口的时候更新),按clicktime排序查询)
主要信息列表(如商品列表,新闻列表)中使用,显示最近点击的或最新添加的5条记录就行'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code,  "data":{"currPage":1,"totalPage":1,"total":1,"pageSize":10,"list":[]}}req_dict = request.session.get("req_dict")if "clicknum"  in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji):req_dict['sort']='clicknum'elif "browseduration"  in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji):req_dict['sort']='browseduration'else:req_dict['sort']='clicktime'req_dict['order']='desc'msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \msg['data']['pageSize']  = ruzhudengji.page(ruzhudengji,ruzhudengji, req_dict)return JsonResponse(msg, encoder=CustomJsonEncoder)#分类列表
def ruzhudengji_lists(request):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code,  "data":[]}msg['data'],_,_,_,_  = ruzhudengji.page(ruzhudengji, ruzhudengji, {})return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_query(request):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}try:query_result = ruzhudengji.objects.filter(**request.session.get("req_dict")).values()msg['data'] = query_result[0]except Exception as e:msg['code'] = crud_error_codemsg['msg'] = f"发生错误:{e}"return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_list(request):'''前台分页'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code,  "data":{"currPage":1,"totalPage":1,"total":1,"pageSize":10,"list":[]}}req_dict = request.session.get("req_dict")#获取全部列名columns=  ruzhudengji.getallcolumn( ruzhudengji, ruzhudengji)if "vipread" in req_dict and "vipread" not in columns:del req_dict["vipread"]#表属性[foreEndList]前台list:和后台默认的list列表页相似,只是摆在前台,否:指没有此页,是:表示有此页(不需要登陆即可查看),前要登:表示有此页且需要登陆后才能查看try:__foreEndList__=ruzhudengji.__foreEndList__except:__foreEndList__=Nonetry:__foreEndListAuth__=ruzhudengji.__foreEndListAuth__except:__foreEndListAuth__=None#authSeparatetry:__authSeparate__=ruzhudengji.__authSeparate__except:__authSeparate__=Noneif __foreEndListAuth__ =="是" and __authSeparate__=="是":tablename=request.session.get("tablename")if tablename!="users":req_dict['userid']=request.session.get("params",{"id":0}).get("id")tablename = request.session.get("tablename")if tablename == "users" and req_dict.get("userid") != None:#判断是否存在userid列名del req_dict["userid"]else:__isAdmin__ = NoneallModels = apps.get_app_config('main').get_models()for m in allModels:if m.__tablename__==tablename:try:__isAdmin__ = m.__isAdmin__except:__isAdmin__ = Nonebreakif __isAdmin__ == "是":if req_dict.get("userid"):# del req_dict["userid"]passelse:#非管理员权限的表,判断当前表字段名是否有useridif "userid" in columns:try:passexcept:pass#当列属性authTable有值(某个用户表)[该列的列名必须和该用户表的登陆字段名一致],则对应的表有个隐藏属性authTable为”是”,那么该用户查看该表信息时,只能查看自己的try:__authTables__=ruzhudengji.__authTables__except:__authTables__=Noneif __authTables__!=None and  __authTables__!={} and __foreEndListAuth__=="是":for authColumn,authTable in __authTables__.items():if authTable==tablename:try:del req_dict['userid']except:passparams = request.session.get("params")req_dict[authColumn]=params.get(authColumn)username=params.get(authColumn)breakif ruzhudengji.__tablename__[:7]=="discuss":try:del req_dict['userid']except:passq = Q()msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \msg['data']['pageSize']  = ruzhudengji.page(ruzhudengji, ruzhudengji, req_dict, request, q)return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_save(request):'''后台新增'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}req_dict = request.session.get("req_dict")if 'clicktime' in req_dict.keys():del req_dict['clicktime']tablename=request.session.get("tablename")__isAdmin__ = NoneallModels = apps.get_app_config('main').get_models()for m in allModels:if m.__tablename__==tablename:try:__isAdmin__ = m.__isAdmin__except:__isAdmin__ = Nonebreak#获取全部列名columns=  ruzhudengji.getallcolumn( ruzhudengji, ruzhudengji)if tablename!='users' and req_dict.get("userid")!=None and 'userid' in columns  and __isAdmin__!='是':params=request.session.get("params")req_dict['userid']=params.get('id')if 'addtime' in req_dict.keys():del req_dict['addtime']error= ruzhudengji.createbyreq(ruzhudengji,ruzhudengji, req_dict)if error!=None:msg['code'] = crud_error_codemsg['msg'] = errorreturn JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_add(request):'''前台新增'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}req_dict = request.session.get("req_dict")tablename=request.session.get("tablename")#获取全部列名columns=  ruzhudengji.getallcolumn( ruzhudengji, ruzhudengji)try:__authSeparate__=ruzhudengji.__authSeparate__except:__authSeparate__=Noneif __authSeparate__=="是":tablename=request.session.get("tablename")if tablename!="users" and 'userid' in columns:try:req_dict['userid']=request.session.get("params").get("id")except:passtry:__foreEndListAuth__=ruzhudengji.__foreEndListAuth__except:__foreEndListAuth__=Noneif __foreEndListAuth__ and __foreEndListAuth__!="否":tablename=request.session.get("tablename")if tablename!="users":req_dict['userid']=request.session.get("params").get("id")if 'addtime' in req_dict.keys():del req_dict['addtime']error= ruzhudengji.createbyreq(ruzhudengji,ruzhudengji, req_dict)if error!=None:msg['code'] = crud_error_codemsg['msg'] = errorreturn JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_thumbsup(request,id_):'''点赞:表属性thumbsUp[是/否],刷表新增thumbsupnum赞和crazilynum踩字段,'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}req_dict = request.session.get("req_dict")id_=int(id_)type_=int(req_dict.get("type",0))rets=ruzhudengji.getbyid(ruzhudengji,ruzhudengji,id_)update_dict={"id":id_,}if type_==1:#赞update_dict["thumbsupnum"]=int(rets[0].get('thumbsupnum'))+1elif type_==2:#踩update_dict["crazilynum"]=int(rets[0].get('crazilynum'))+1error = ruzhudengji.updatebyparams(ruzhudengji,ruzhudengji, update_dict)if error!=None:msg['code'] = crud_error_codemsg['msg'] = errorreturn JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_info(request,id_):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}data = ruzhudengji.getbyid(ruzhudengji,ruzhudengji, int(id_))if len(data)>0:msg['data']=data[0]if msg['data'].__contains__("reversetime"):if isinstance(msg['data']['reversetime'], datetime.datetime):msg['data']['reversetime'] = msg['data']['reversetime'].strftime("%Y-%m-%d %H:%M:%S")else:if msg['data']['reversetime'] != None:reversetime = datetime.datetime.strptime(msg['data']['reversetime'], '%Y-%m-%d %H:%M:%S')msg['data']['reversetime'] = reversetime.strftime("%Y-%m-%d %H:%M:%S")#浏览点击次数try:__browseClick__= ruzhudengji.__browseClick__except:__browseClick__=Noneif __browseClick__=="是"  and  "clicknum"  in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji):try:clicknum=int(data[0].get("clicknum",0))+1except:clicknum=0+1click_dict={"id":int(id_),"clicknum":clicknum,"clicktime":datetime.datetime.now()}ret=ruzhudengji.updatebyparams(ruzhudengji,ruzhudengji,click_dict)if ret!=None:msg['code'] = crud_error_codemsg['msg'] = retreturn JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_detail(request,id_):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}data =ruzhudengji.getbyid(ruzhudengji,ruzhudengji, int(id_))if len(data)>0:msg['data']=data[0]if msg['data'].__contains__("reversetime"):if isinstance(msg['data']['reversetime'], datetime.datetime):msg['data']['reversetime'] = msg['data']['reversetime'].strftime("%Y-%m-%d %H:%M:%S")else:if msg['data']['reversetime'] != None:reversetime = datetime.datetime.strptime(msg['data']['reversetime'], '%Y-%m-%d %H:%M:%S')msg['data']['reversetime'] = reversetime.strftime("%Y-%m-%d %H:%M:%S")#浏览点击次数try:__browseClick__= ruzhudengji.__browseClick__except:__browseClick__=Noneif __browseClick__=="是"   and  "clicknum"  in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji):try:clicknum=int(data[0].get("clicknum",0))+1except:clicknum=0+1click_dict={"id":int(id_),"clicknum":clicknum,"clicktime":datetime.datetime.now()}ret=ruzhudengji.updatebyparams(ruzhudengji,ruzhudengji,click_dict)if ret!=None:msg['code'] = crud_error_codemsg['msg'] = retreturn JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_update(request):''''''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}req_dict = request.session.get("req_dict")if 'clicktime' in req_dict.keys() and req_dict['clicktime']=="None":del req_dict['clicktime']if req_dict.get("mima") and "mima" not in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji) :del req_dict["mima"]if req_dict.get("password") and "password" not in ruzhudengji.getallcolumn(ruzhudengji,ruzhudengji) :del req_dict["password"]try:del req_dict["clicknum"]except:passerror = ruzhudengji.updatebyparams(ruzhudengji, ruzhudengji, req_dict)if error!=None:msg['code'] = crud_error_codemsg['msg'] = errorreturn JsonResponse(msg)def ruzhudengji_delete(request):'''批量删除'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code, "data": {}}req_dict = request.session.get("req_dict")error=ruzhudengji.deletes(ruzhudengji,ruzhudengji,req_dict.get("ids"))if error!=None:msg['code'] = crud_error_codemsg['msg'] = errorreturn JsonResponse(msg)def ruzhudengji_vote(request,id_):'''浏览点击次数(表属性[browseClick:是/否],点击字段(clicknum),调用info/detail接口的时候后端自动+1)、投票功能(表属性[vote:是/否],投票字段(votenum),调用vote接口后端votenum+1)
统计商品或新闻的点击次数;提供新闻的投票功能'''if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": mes.normal_code}data= ruzhudengji.getbyid(ruzhudengji, ruzhudengji, int(id_))for i in data:votenum=i.get('votenum')if votenum!=None:params={"id":int(id_),"votenum":votenum+1}error=ruzhudengji.updatebyparams(ruzhudengji,ruzhudengji,params)if error!=None:msg['code'] = crud_error_codemsg['msg'] = errorreturn JsonResponse(msg)def ruzhudengji_importExcel(request):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": "成功", "data": {}}excel_file = request.FILES.get("file", "")file_type = excel_file.name.split('.')[1]if file_type in ['xlsx', 'xls']:data = xlrd.open_workbook(filename=None, file_contents=excel_file.read())table = data.sheets()[0]rows = table.nrowstry:for row in range(1, rows):row_values = table.row_values(row)req_dict = {}ruzhudengji.createbyreq(ruzhudengji, ruzhudengji, req_dict)except:passelse:msg = {"msg": "文件类型错误","code": 500}return JsonResponse(msg)def ruzhudengji_autoSort2(request):return JsonResponse({"code": 0, "msg": '',  "data":{}})# (按值统计)时间统计类型
def ruzhudengji_value(request, xColumnName, yColumnName, timeStatType):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": "成功", "data": {}}where = ' where 1 = 1 'token = request.META.get('HTTP_TOKEN')decode_str = eval(base64.b64decode(token).decode("utf8"))if decode_str['tablename'] == 'yonghu':where = where + " and yonghuzhanghao ='{0}' ".format(decode_str['params']['yonghuzhanghao'])sql = ''if timeStatType == '日':sql = "SELECT DATE_FORMAT({0}, '%Y-%m-%d') {0}, ROUND(sum({1}),2) total FROM ruzhudengji {2} GROUP BY DATE_FORMAT({0}, '%Y-%m-%d')".format(xColumnName, yColumnName, where, '%Y-%m-%d')if timeStatType == '月':sql = "SELECT DATE_FORMAT({0}, '%Y-%m') {0}, ROUND(sum({1}),2) total FROM ruzhudengji {2} GROUP BY DATE_FORMAT({0}, '%Y-%m')".format(xColumnName, yColumnName, where, '%Y-%m')if timeStatType == '年':sql = "SELECT DATE_FORMAT({0}, '%Y') {0}, ROUND(sum({1}),2) total FROM ruzhudengji {2} GROUP BY DATE_FORMAT({0}, '%Y')".format(xColumnName, yColumnName, where, '%Y')L = []cursor = connection.cursor()cursor.execute(sql)desc = cursor.descriptiondata_dict = [dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall()] for online_dict in data_dict:for key in online_dict:if 'datetime.datetime' in str(type(online_dict[key])):online_dict[key] = online_dict[key].strftime("%Y-%m-%d %H:%M:%S")else:passL.append(online_dict)msg['data'] = Lreturn JsonResponse(msg, encoder=CustomJsonEncoder)# 按值统计
def ruzhudengji_o_value(request, xColumnName, yColumnName):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": "成功", "data": {}}where = ' where 1 = 1 'token = request.META.get('HTTP_TOKEN')decode_str = eval(base64.b64decode(token).decode("utf8"))if decode_str['tablename'] == 'yonghu':where = where + " and yonghuzhanghao ='{0}' ".format(decode_str['params']['yonghuzhanghao'])sql = "SELECT {0}, ROUND(sum({1}),2) AS total FROM ruzhudengji {2} GROUP BY {0}".format(xColumnName, yColumnName, where)L = []cursor = connection.cursor()cursor.execute(sql)desc = cursor.descriptiondata_dict = [dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall()] for online_dict in data_dict:for key in online_dict:if 'datetime.datetime' in str(type(online_dict[key])):online_dict[key] = online_dict[key].strftime("%Y-%m-%d %H:%M:%S")else:passL.append(online_dict)msg['data'] = Lreturn JsonResponse(msg, encoder=CustomJsonEncoder)# (按值统计)时间统计类型(多)
def ruzhudengji_valueMul(request, xColumnName, timeStatType):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": "成功", "data": []}req_dict = request.session.get("req_dict")where = ' where 1 = 1 'token = request.META.get('HTTP_TOKEN')decode_str = eval(base64.b64decode(token).decode("utf8"))if decode_str['tablename'] == 'yonghu':where = where + " and yonghuzhanghao ='{0}' ".format(decode_str['params']['yonghuzhanghao'])for item in req_dict['yColumnNameMul'].split(','):sql = ''if timeStatType == '日':sql = "SELECT DATE_FORMAT({0}, '%Y-%m-%d') {0}, ROUND(sum({1}),2) total FROM ruzhudengji {2} GROUP BY DATE_FORMAT({0}, '%Y-%m-%d') LIMIT 10".format(xColumnName, item, where, '%Y-%m-%d')if timeStatType == '月':sql = "SELECT DATE_FORMAT({0}, '%Y-%m') {0}, ROUND(sum({1}),2) total FROM ruzhudengji {2} GROUP BY DATE_FORMAT({0}, '%Y-%m') LIMIT 10".format(xColumnName, item, where, '%Y-%m')if timeStatType == '年':sql = "SELECT DATE_FORMAT({0}, '%Y') {0}, ROUND(sum({1}),2) total FROM ruzhudengji {2} GROUP BY DATE_FORMAT({0}, '%Y') LIMIT 10".format(xColumnName, item, where, '%Y')L = []cursor = connection.cursor()cursor.execute(sql)desc = cursor.descriptiondata_dict = [dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall()] for online_dict in data_dict:for key in online_dict:if 'datetime.datetime' in str(type(online_dict[key])):online_dict[key] = online_dict[key].strftime("%Y-%m-%d %H:%M:%S")else:passL.append(online_dict)msg['data'].append(L)return JsonResponse(msg, encoder=CustomJsonEncoder)# (按值统计(多))
def ruzhudengji_o_valueMul(request, xColumnName):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": "成功", "data": []}req_dict = request.session.get("req_dict")where = ' where 1 = 1 'token = request.META.get('HTTP_TOKEN')decode_str = eval(base64.b64decode(token).decode("utf8"))if decode_str['tablename'] == 'yonghu':where = where + " and yonghuzhanghao ='{0}' ".format(decode_str['params']['yonghuzhanghao'])for item in req_dict['yColumnNameMul'].split(','):sql = "SELECT {0}, ROUND(sum({1}),2) AS total FROM ruzhudengji {2} GROUP BY {0} LIMIT 10".format(xColumnName, item, where)L = []cursor = connection.cursor()cursor.execute(sql)desc = cursor.descriptiondata_dict = [dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall()] for online_dict in data_dict:for key in online_dict:if 'datetime.datetime' in str(type(online_dict[key])):online_dict[key] = online_dict[key].strftime("%Y-%m-%d %H:%M:%S")else:passL.append(online_dict)msg['data'].append(L)return JsonResponse(msg, encoder=CustomJsonEncoder)def ruzhudengji_group(request, columnName):if request.method in ["POST", "GET"]:msg = {"code": normal_code, "msg": "成功", "data": {}}where = ' where 1 = 1 'token = request.META.get('HTTP_TOKEN')decode_str = eval(base64.b64decode(token).decode("utf8"))if decode_str['tablename'] == 'yonghu':where = where + " and yonghuzhanghao ='{0}' ".format(decode_str['params']['yonghuzhanghao'])sql = "SELECT COUNT(*) AS total, " + columnName + " FROM ruzhudengji " + where + " GROUP BY " + columnNameL = []cursor = connection.cursor()cursor.execute(sql)desc = cursor.descriptiondata_dict = [dict(zip([col[0] for col in desc], row)) for row in cursor.fetchall()] for online_dict in data_dict:for key in online_dict:if 'datetime.datetime' in str(type(online_dict[key])):online_dict[key] = online_dict[key].strftime("%Y-%m-%d")else:passL.append(online_dict)msg['data'] = Lreturn JsonResponse(msg, encoder=CustomJsonEncoder)

四、效果图

五 、源码获取

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

下方名片联系我即可!!


大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com