日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:287日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女视频黄久久| 国产成人精品999在线观看| 国产在线观看91一区二区三区| 视频一区欧美精品| 99久久精品费精品国产| 日本v片在线高清不卡在线观看| 亚洲婷婷免费| 福利片在线一区二区| 99国产一区| 亚洲手机视频| 91精品亚洲| 日韩精品欧美激情一区二区| 丁香婷婷久久| 精品日本视频| 国产极品嫩模在线观看91精品| 香蕉久久久久久| 亚洲一区二区日韩| 高清一区二区三区| 国产96在线亚洲| 久久中文字幕二区| 99久久精品国产亚洲精品| 午夜影院一区| 欧美va天堂在线| 午夜久久美女| 亚洲国产不卡| 久久国产88| 午夜一级久久| 中文字幕乱码亚洲无线精品一区| 蜜桃一区二区三区在线观看| 亚洲欧洲一区| 国产精品嫩草99av在线| 日韩欧美2区| 欧美精品三级在线| 国产精品麻豆成人av电影艾秋| 精品高清久久| 久久精品国产一区二区| 美女免费视频一区| 国产成人黄色| 啪啪国产精品| 亚洲精品国模| 日韩精品一区二区三区免费视频| 精品欧美视频| 久久久久国产| 国产模特精品视频久久久久| 国产欧美日韩精品高清二区综合区| 国产精品最新| 日产精品一区二区| 欧美~级网站不卡| 午夜国产欧美理论在线播放 | 国产精一区二区| 久久这里只有精品一区二区| 欧美丰满日韩| 欧美精品99| 精品三区视频| 91精品蜜臀一区二区三区在线 | 国产精品白丝一区二区三区| 国产精品99久久免费| 国产91欧美| 自由日本语亚洲人高潮| 深夜福利亚洲| 欧美日一区二区三区在线观看国产免| 老色鬼精品视频在线观看播放| av免费不卡国产观看| 精品在线播放| 午夜天堂精品久久久久| 欧洲av一区二区| 免费在线视频一区| 老司机免费视频一区二区三区| 欧美色图国产精品| 午夜久久av| 久久国产日韩| 日本麻豆一区二区三区视频| 国产麻豆久久| 视频一区二区中文字幕| 欧美专区18| 国产视频一区二区在线播放| 国产精品原创| 国产精品中文字幕亚洲欧美| 精品捆绑调教一区二区三区| 免费人成黄页网站在线一区二区| 国产精品国产三级国产在线观看| 亚洲综合二区| 欧美一级网址| 久久视频一区| 国产伦精品一区二区三区在线播放| 国模 一区 二区 三区| 欧美偷窥清纯综合图区| 91精品1区| 国产精品亚洲综合在线观看| 婷婷丁香综合| 国精品产品一区| 亚洲视频国产精品| 精品中文一区| 国产精品成人国产| 日韩午夜免费| 精品国产一区二区三区2021| 午夜在线精品偷拍| 精品国产不卡| 羞羞答答国产精品www一本| 精品不卡一区| 日韩福利视频导航| 爽好久久久欧美精品| 日韩欧美一区二区三区免费看| 亚洲激情国产| 三上亚洲一区二区| 日韩视频1区| 99久久99视频只有精品| 欧美精品不卡| 91av一区| 免费成人在线影院| 91精品一区国产高清在线gif | 日韩中文字幕区一区有砖一区 | 99在线|亚洲一区二区| 久久xxx视频| 国产日韩中文在线中文字幕| 亚洲欧美日韩高清在线| 国产精品福利在线观看播放| 国产精品嫩草影院在线看| 羞羞答答国产精品www一本| 欧美激情视频一区二区三区在线播放| 日本不卡不码高清免费观看| 欧美日韩国产在线观看网站| 国产一区二区精品久| 捆绑调教美女网站视频一区| 日本成人手机在线| 高清在线一区| 国产精东传媒成人av电影| 亚洲日韩视频| 日韩激情av在线| 天堂av在线一区| 久久电影一区| 亚洲精品国产日韩| 久久亚洲图片| 亚洲欧洲av| 免费人成精品欧美精品| 激情久久久久久| 欧美日韩激情| 国产一区亚洲| 美女被久久久| 日韩视频二区| 一区久久精品| 欧美aa在线观看| 国产精品一区二区三区av麻| 日韩精品一二三区| 午夜久久99| 狠狠干综合网| 亚洲精品电影| 精品在线91| 午夜精品影院| 99日韩精品| 亚洲自拍另类| 蜜臀久久99精品久久久久宅男| 夜夜嗨一区二区| 欧美日韩第一| 另类激情亚洲| 亚洲欧洲av| 首页亚洲欧美制服丝腿| 视频一区欧美日韩| 中文字幕亚洲在线观看| 日韩中文字幕| 日韩精品视频网站| 欧美日韩中出| 免费在线亚洲欧美| 久久伊人国产| 日韩.com| 久久精品av| 99视频精品全部免费在线视频| 欧美a级片一区| 久热综合在线亚洲精品| 麻豆9191精品国产| 亚洲欧美在线专区| 日韩av影院| 国产精品视频一区视频二区| 精品美女在线视频| 丝袜美腿诱惑一区二区三区| 老鸭窝毛片一区二区三区| 日韩影片在线观看| 麻豆视频在线观看免费网站黄| 另类中文字幕国产精品| 美国三级日本三级久久99| 日韩不卡在线观看日韩不卡视频| 欧美黑人做爰爽爽爽| 欧美成人国产| 色婷婷成人网| 精品国产18久久久久久二百| 亚州av乱码久久精品蜜桃| 国产精品免费看| 99日韩精品| 国产精品成人**免费视频| 婷婷激情一区| 欧美日韩亚洲一区二区三区在线| 国内精品伊人| 黄色成人精品网站| 国产精品22p| 欧美日韩一区二区三区视频播放| 日本在线成人| 人人草在线视频| 免费看av不卡| 91亚洲精品视频在线观看| 精品精品99|