成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

瀏覽:236日期: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
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美激情自拍偷拍| 欧美日韩精品免费看| 91麻豆精品秘密| 欧美年轻男男videosbes| 日韩激情视频在线观看| 国产精品日韩欧美一区| 中文字幕在线观看一区| 欧美日韩一区自拍| 国产日韩欧美a| 97久久久精品综合88久久| 精品奇米国产一区二区三区| 国产成人h网站| 欧美精品电影在线播放| 久久99精品国产| 欧美日韩精品是欧美日韩精品| 久久国产三级精品| 欧美日韩一区视频| 国内精品久久久久影院一蜜桃| 欧美日韩一级黄| 国产麻豆精品久久一二三| 91精品国产综合久久精品性色| 国产成人亚洲综合a∨婷婷图片| 日韩欧美国产一区二区在线播放 | 一区二区三区四区五区视频| 国产午夜亚洲精品理论片色戒| 91网址在线看| 国产亚洲va综合人人澡精品| av资源网一区| 国产人久久人人人人爽| 国产在线欧美| 伊人色综合久久天天人手人婷| 国产欧美91| 日韩电影在线免费| 欧美日韩高清一区二区不卡| 国产成人一级电影| 欧美mv和日韩mv的网站| 91蜜桃在线免费视频| 国产精品不卡在线观看| 伊人久久综合| 亚洲一区中文日韩| 日本二三区不卡| 国产精品伊人色| 亚洲精品在线电影| 黄色日韩精品| 亚洲国产精品天堂| 欧美性生活影院| 在线视频综合导航| 精品一区二区在线免费观看| 91精品免费在线| 欧美一区1区三区3区公司| 国产精品毛片高清在线完整版| 伊人蜜桃色噜噜激情综合| 亚洲国产一二三| 欧洲国内综合视频| 岛国精品在线播放| 国产精品美女久久久久aⅴ国产馆| 99精品国产99久久久久久福利| 日欧美一区二区| 欧美一区在线视频| 91在线视频观看| 亚洲综合视频网| 欧美三区在线观看| 成人免费三级在线| 1区2区3区欧美| 色悠悠久久综合| 成人成人成人在线视频| 亚洲色图色小说| 欧美三区免费完整视频在线观看| 成人深夜在线观看| 亚洲精选免费视频| 欧美另类久久久品| 欧美精品偷拍| 日韩电影一二三区| 亚洲精品在线免费播放| 在线亚洲美日韩| 国产精品综合久久| 亚洲婷婷在线视频| 欧美理论在线播放| 亚洲网友自拍| 美国毛片一区二区| 国产欧美一区二区三区在线看蜜臀 | 极品中文字幕一区| 免费在线观看视频一区| 久久久久久久久久久久电影| 新67194成人永久网站| 国产成人免费高清| 一区二区三区中文字幕| 日韩一区二区在线观看视频播放 | 在线不卡一区二区| 精品福利电影| 韩国v欧美v亚洲v日本v| 成人免费一区二区三区在线观看| 欧美日韩黄色一区二区| 尤物网精品视频| 国产一区二区三区四区在线观看 | 国产在线国偷精品产拍免费yy| 国产精品美女久久久久aⅴ国产馆| 在线欧美日韩精品| 国一区二区在线观看| 久久av资源网| 亚洲色图.com| 日韩欧美电影一二三| 亚洲综合日本| 99r国产精品| 蜜桃av噜噜一区| 国产精品欧美极品| 欧美精品vⅰdeose4hd| 亚洲免费大片| 成人av在线播放网址| 午夜av区久久| 欧美经典三级视频一区二区三区| 欧美三区在线视频| 中文在线不卡| 色综合天天天天做夜夜夜夜做| 免费不卡在线视频| 亚洲视频在线观看三级| 伊甸园精品99久久久久久| 国产精品家庭影院| 777久久久精品| 国产精品视频福利| 91免费在线播放| 激情五月播播久久久精品| 亚洲免费观看高清完整版在线观看熊| 欧美一二三四区在线| 色菇凉天天综合网| 亚洲欧洲一区| 欧美在线网址| 成人影视亚洲图片在线| 麻豆视频一区二区| 亚洲一区二区三区四区在线| 国产精品久久影院| 欧美mv日韩mv国产网站app| 欧美日韩精品一二三区| 久久一二三区| 99这里有精品| 亚洲欧美伊人| www.av精品| 精品在线免费视频| 午夜激情一区二区| 一区二区三区日韩精品| 综合色天天鬼久久鬼色| 久久久久国产精品麻豆ai换脸 | 555夜色666亚洲国产免| 色婷婷一区二区三区四区| 国产视频久久| 亚洲三级视频| 国产专区一区| 成人午夜免费av| 国产在线视频不卡二| 免费观看一级欧美片| 天天综合天天做天天综合| 亚洲综合激情网| 亚洲欧洲国产日韩| 国产精品传媒视频| 国产精品国产三级国产有无不卡| 久久久久国产精品麻豆| 久久综合狠狠综合久久激情 | 久久先锋影音av鲁色资源| 欧美一卡二卡在线| 91精品国产免费久久综合| 欧美私模裸体表演在线观看| 老牛影视一区二区三区| 久久久亚洲一区| 久久综合久久久| 色呦呦网站一区| 日本精品一区二区三区高清| 色婷婷精品大在线视频| 91精彩视频在线| 欧美丝袜自拍制服另类| 欧美日韩一区三区四区| 欧美日韩国产免费| 欧美精品色综合| 6080午夜不卡| 欧美一二三四区在线| 日韩欧美一区中文| 日韩精品中文字幕一区二区三区| 欧美一区二区视频免费观看| 日韩一级免费一区| 精品国产在天天线2019| 亚洲精品一区二区三区蜜桃下载 | 免费在线观看日韩欧美| 日韩av在线免费观看不卡| 日韩国产高清影视| 美洲天堂一区二卡三卡四卡视频 | 丰满亚洲少妇av| av中文一区二区三区| 91视视频在线直接观看在线看网页在线看 | www.99精品| 欧美激情第二页| 欧美日韩综合久久| 亚洲国产欧美国产综合一区| 一本色道精品久久一区二区三区 | 一本色道久久综合狠狠躁的推荐| 91国偷自产一区二区开放时间 | 日韩国产一二三区| 国产在线国偷精品产拍免费yy | 丝袜a∨在线一区二区三区不卡| 日本美女一区二区三区| 韩国理伦片一区二区三区在线播放| 国产精品香蕉一区二区三区|