电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Django ORM實現按天獲取數據去重求和例子

瀏覽:186日期:2024-10-05 15:33:07

我就廢話不多說了,大家還是直接看代碼吧!

def total_data(request): data = request_body(request, ’POST’) if not data: return http_return(400, ’參數錯誤’) # 前端傳入毫秒為單位的時間戳 startTimestamp = data.get(’startTime’, ’’) endTimestamp = data.get(’endTime’, ’’) if startTimestamp and endTimestamp: startTimestamp = int(startTimestamp/1000) endTimestamp = int(endTimestamp/1000) else: return http_return(400, ’參數有誤’) # 小于2019-05-30 00:00:00的時間不合法 if endTimestamp < startTimestamp or endTimestamp <= 1559145600 or startTimestamp <= 1559145600: return http_return(400, ’無效時間’) if startTimestamp and endTimestamp: # 給定時間查詢 startTime = datetime.fromtimestamp(startTimestamp) endTime = datetime.fromtimestamp(endTimestamp) t1 = datetime(startTime.year, startTime.month, startTime.day) t2 = datetime(endTime.year, endTime.month, endTime.day, 23, 59, 59, 999999) # 用戶總人數 totalUsers = User.objects.exclude(status=’destroy’).count() # 音頻總數 totalAudioStory = AudioStory.objects.filter(isDelete=False).count() # 專輯總數 totalAlbums = Album.objects.filter(isDelete=False).count() # 新增用戶人數 newUsers = User.objects.filter(createTime__range=(t1, t2)).exclude(status=’destroy’).count() # 活躍用戶人數 activityUsers = LoginLog.objects.filter(createTime__range=(t1, t2), isManager=False).values(’userUuid_id’). annotate(Count(’userUuid_id’)).count() # 新增音頻數 newAudioStory = AudioStory.objects.filter(createTime__range=(t1, t2)).count() # 男性 male = User.objects.filter(gender=1).exclude(status=’destroy’).count() # 女性 female = User.objects.filter(gender=2).exclude(status=’destroy’).count() # 未知 unkonwGender = User.objects.filter(gender=0).exclude(status=’destroy’).count() # 模板音頻 aduioStoryCount = AudioStory.objects.filter( isDelete=False, audioStoryType=1, isUpload=1, createTime__range=(t1, t2)).count() # 自由錄制 freedomStoryCount = AudioStory.objects.filter( isDelete=False, audioStoryType=0, isUpload=1, createTime__range=(t1, t2)).count() # 兒歌 tags1 = Tag.objects.filter(code='RECORDTYPE', name=’兒歌’).first() tags1Count = tags1.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)).count() # 兒歌作品數 user1Count = tags1.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)). values(’userUuid_id’).annotate(Count(’userUuid_id’)).count()# 錄音類型人數,去重 # result = Tag.objects.filter(code='RECORDTYPE').annotate(Count(’tagsAudioStory’)) # 父母學堂 tags2 = Tag.objects.filter(code='RECORDTYPE', name=’父母學堂’).first() tags2Count = tags2.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)).count() user2Count = tags2.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)). values(’userUuid_id’).annotate(Count(’userUuid_id’)).count() # 國學 tags3 = Tag.objects.filter(code='RECORDTYPE', name=’國學’).first() tags3Count = tags3.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)).count() user3Count = tags3.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)). values(’userUuid_id’).annotate(Count(’userUuid_id’)).count() # 英文 tags4 = Tag.objects.filter(code='RECORDTYPE', name=’英文’).first() tags4Count = tags4.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)).count() user4Count = tags4.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)). values(’userUuid_id’).annotate(Count(’userUuid_id’)).count() # 其他 tags5 = Tag.objects.filter(code='RECORDTYPE', name=’其他’).first() tags5Count = tags5.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)).count() user5Count = tags5.tagsAudioStory.filter(isDelete=False, createTime__range=(t1, t2)). values(’userUuid_id’).annotate(Count(’userUuid_id’)).count() recordTypePercentage = [ {’name’: ’兒歌’, ’tagsNum’: tags1Count, ’userNum’: user1Count}, {’name’: ’兒歌’, ’tagsNum’: tags2Count, ’userNum’: user2Count}, {’name’: ’國學’, ’tagsNum’: tags3Count, ’userNum’: user3Count}, {’name’: ’英文’, ’tagsNum’: tags4Count, ’userNum’: user4Count}, {’name’: ’其他’, ’tagsNum’: tags5Count, ’userNum’: user5Count} ] # 活躍用戶排行 data1_list = [] # result = AudioStory.objects.filter(isDelete=False, createTime__range=(t1, t2)).values(’userUuid_id’).annotate(Count(’userUuid_id’))[:1] res = User.objects.annotate(audioStory_count_by_user = Count('useAudioUuid')).order_by(’-audioStory_count_by_user’)[:5] for index,item in enumerate(res.values()): data = {’orderNum’: index+1,’name’: item[’nickName’],’recordCount’: item[’audioStory_count_by_user’] } data1_list.append(data) # 熱門錄制排行 data2_list = [] res = Story.objects.filter(status='normal', createTime__range=(t1, t2)).order_by(’-recordNum’)[:5] for index,item in enumerate(res.values()): data = {’orderNum’: index + 1 or -1,’name’: item[’name’] or ’’,’recordNum’: item[’recordNum’] or 0 } data2_list.append(data) # 熱門播放排行 data3_list = [] audioStory = AudioStory.objects.filter(isDelete=False, createTime__range=(t1, t2)).order_by(’-playTimes’)[:5] for index,item in enumerate(audioStory): data = {’orderNum’: index + 1,’name’: item.storyUuid.name if item.audioStoryType else item.name,’playTimes’: item.playTimes } data3_list.append(data) # 圖表數據--新增用戶 graph1 = User.objects.filter(createTime__range=(t1, t2)). extra(select={'time': 'DATE_FORMAT(createTime,’%%Y-%%m-%%e’)'}). order_by(’time’).values(’time’) .annotate(userNum=Count(’createTime’)).values(’time’, ’userNum’) if graph1: graph1 = list(graph1) else: graph1 = [] # 活躍用戶 graph2 = LoginLog.objects.filter(createTime__range=(t1, t2), isManager=False). extra(select={'time': 'DATE_FORMAT(createTime,’%%Y-%%m-%%e’)'}). values(’time’).annotate(userNum=Count(’createTime’, distinct=True)).values(’time’, ’userNum’) if graph2: graph2 = list(graph2) else: graph2 = [] return http_return(200, ’OK’, {’totalUsers’: totalUsers, # 總用戶人數’totalAudioStory’: totalAudioStory, # 音頻總數’totalAlbums’: totalAlbums, # 總的專輯數’newUsers’: newUsers,# 新增用戶人數’activityUsers’: activityUsers, # 活躍用戶人數’newAudioStory’: newAudioStory, # 新增音頻數’activityUsersRank’: data1_list, # 活躍用戶排行’male’: male, # 男性’female’: female, # 女性’unkonwGender’: unkonwGender, # 未知性別’aduioStoryCount’: aduioStoryCount, # 模板音頻數量’freedomStoryCount’: freedomStoryCount, # 自由錄制音頻數量’recordTypePercentage’: recordTypePercentage,’hotRecordRank’: data2_list, # 熱門錄制排行’hotPlayAudioStoryRank’: data3_list, # 熱門播放排行’newUserGraph’: graph1, # 新增用戶折線圖’activityUserGraph’: graph2, # 活躍用戶折線圖 })

補充知識:Django 對符合條件的某個字段進行求和,聚合函數annotate()

開發環境:Ubuntu16.04+Django 1.11.9+Python2.7

對符合條件的某個字段求和 

之前在開發的時候,有同事問Django是否存在著這樣的方法,可以直接將符合條件的某個字段直接求和.

當時不知道這樣的方法是否存在,但是想了想自己解決這類似問題的方法,先用filter將符合條件的取出來,然后進行for循環,取出需要的字段,進行求和.感覺是挺low的,于是一起Baidu,寫代碼測試最后找到了可以求值的方法,聚合函數annotate().

from django.db.models import Sumfrom models import Bookall_price = Book.objects.values(’price’).annotate(num_books=Sum(’price’)).filter(author=’Yu’)print all_price[0][’num_books’]

輸出結果:650

上面的參數換個順序,不會出錯但不符合預期結果.

all_price = Book.objects.annotate(num_books=Sum(’price’)).filter(author=’Yu’).values(’price’)print all_youxibi[0][’num_books’]

輸出結果:’nums_book’

以上這篇Django ORM實現按天獲取數據去重求和例子就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 东莞猎头公司_深圳猎头公司_广州猎头公司-广东万诚猎头提供企业中高端人才招聘服务 | 登车桥动力单元-非标液压泵站-非标液压系统-深圳市三好科技有限公司 | 火锅加盟_四川成都火锅店加盟_中国火锅连锁品牌十强_朝天门火锅【官网】 | 国资灵活用工平台_全国灵活用工平台前十名-灵活用工结算小帮手 | 示波器高压差分探头-国产电流探头厂家-南京桑润斯电子科技有限公司 | 塑钢件_塑钢门窗配件_塑钢配件厂家-文安县启泰金属制品有限公司 深圳南财多媒体有限公司介绍 | 济南宣传册设计-画册设计_济南莫都品牌设计公司 | 查分易-成绩发送平台官网| 东莞海恒试验仪器设备有限公司 | 东风体检车厂家_公共卫生体检车_医院体检车_移动体检车-锦沅科贸 | 外贸网站建设-外贸网站设计制作开发公司-外贸独立站建设【企术】 | 吹塑加工_大型吹塑加工_滚塑代加工-莱力奇吹塑加工有限公司 | 贝朗斯动力商城(BRCPOWER.COM) - 买叉车蓄电池上贝朗斯商城,价格更超值,品质有保障! | 变色龙云 - 打包app_原生app_在线制作平台_短链接_ip查询 | 学叉车培训|叉车证报名|叉车查询|叉车证怎么考-工程机械培训网 | 齿式联轴器-弹性联轴器-联轴器厂家-江苏诺兴传动联轴器制造有限公司 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 钛合金标准件-钛合金螺丝-钛管件-钛合金棒-钛合金板-钛合金锻件-宝鸡远航钛业有限公司 | 天津散热器_天津暖气片_天津安尼威尔散热器制造有限公司 | 绿叶|绿叶投资|健康产业_绿叶投资集团有限公司 | 环讯传媒,永康网络公司,永康网站建设,永康小程序开发制作,永康网站制作,武义网页设计,金华地区网站SEO优化推广 - 永康市环讯电子商务有限公司 | 济南拼接屏_山东液晶拼接屏_济南LED显示屏—维康国际官网 | 恒温槽_恒温水槽_恒温水浴槽-上海方瑞仪器有限公司 | hc22_hc22价格_hc22哈氏合金—东锜特殊钢 | 「阿尔法设计官网」工业设计_产品设计_产品外观设计 深圳工业设计公司 | 航空铝型材,7系铝型材挤压,硬质阳*氧化-余润铝制品 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 油冷式_微型_TDY电动滚筒_外装_外置式电动滚筒厂家-淄博秉泓机械有限公司 | 裹包机|裹膜机|缠膜机|绕膜机-上海晏陵智能设备有限公司 | 小区健身器材_户外健身器材_室外健身器材_公园健身路径-沧州浩然体育器材有限公司 | 焊管生产线_焊管机组_轧辊模具_焊管设备_焊管设备厂家_石家庄翔昱机械 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 深圳VI设计-画册设计-LOGO设计-包装设计-品牌策划公司-[智睿画册设计公司] | 陕西自考报名_陕西自学考试网 | 废气处理_废气处理设备_工业废气处理_江苏龙泰环保设备制造有限公司 | 不锈钢散热器,冷却翅片管散热器厂家-无锡市烨晟化工装备科技有限公司 | 识禅_对禅的了解,从这里开始 | 手术示教系统-数字化手术室系统-林之硕医疗云智能视频平台 | 磁力抛光机_磁力研磨机_磁力去毛刺机-冠古设备厂家|维修|租赁【官网】 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | PAS糖原染色-CBA流式多因子-明胶酶谱MMP-上海研谨生物科技有限公司 |