當前位置: 首頁>>代碼示例>>Python>>正文


Python database.DbSession類代碼示例

本文整理匯總了Python中yt_crawler.backend.database.DbSession的典型用法代碼示例。如果您正苦於以下問題:Python DbSession類的具體用法?Python DbSession怎麽用?Python DbSession使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了DbSession類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: get_duration_of_all_videos_per_youtuber

 def get_duration_of_all_videos_per_youtuber():
     existing = DbSession.query(func.count(Video.video_id), Youtuber.channel_title).filter(Video.type.isnot(VideoType.EXISTING.video_type_id)).join(Youtuber).group_by(Video.channel_id).all()
     purged = DbSession.query(func.count(PurgedVideo.video_id), Youtuber.channel_title).join(Youtuber).group_by(PurgedVideo.channel_id).all()
     existing_result = [(ex[0], ex[1]) for ex in existing]
     for ex in existing_result:
         matching = next((purged_video for purged_video in purged if ex[1] == purged_video[1]), None)
         if matching is not None:
             existing_result[existing_result.index(ex)] = (ex[0] + matching[0], ex[1])
     return existing_result
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:9,代碼來源:youtube_model.py

示例2: get_existing_stat_for_youtuber

 def get_existing_stat_for_youtuber(self):
     existing = DbSession.query(func.count(Video.video_id), func.sum(Video.size)).filter(and_(Video.type.isnot(VideoType.EXISTING.video_type_id), (Video.channel_id == self.channel_id))).all()
     purged = DbSession.query(func.count(PurgedVideo.video_id), func.sum(PurgedVideo.size)).filter(PurgedVideo.channel_id == self.channel_id).all()
     old_statistic = DbSession.query(Statistic.number_downloaded, Statistic.size_downloaded).filter(Statistic.channel_id == self.channel_id).all()
     count = 0
     size = 0
     # old_statistic is grouped into types
     for stat in old_statistic:
         count += int(stat[0])
         size += int(stat[1])
     return [int(existing[0][0]) + int(purged[0][0]) + count, int(existing[0][1]) + int(purged[0][1]) + size]
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:11,代碼來源:youtube_model.py

示例3: setup_constants

 def setup_constants():
     VideoType.PLAYLIST_ITEM = VideoType.load(name=DownloadFlag.PLAYLIST_ITEM.value)
     VideoType.SCHEDULED = VideoType.load(name=DownloadFlag.SCHEDULED.value)
     VideoType.CRAWLED = VideoType.load(name=DownloadFlag.CRAWLED.value)
     VideoType.EXISTING = VideoType.load(name=DownloadFlag.EXISTING.value)
     DbSession.expunge(VideoType.PLAYLIST_ITEM)
     DbSession.expunge(VideoType.SCHEDULED)
     DbSession.expunge(VideoType.CRAWLED)
     DbSession.expunge(VideoType.EXISTING)
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:9,代碼來源:youtube_model.py

示例4: insert_contants

 def insert_contants():
     if not ErrorFatality.exists(error_name='info'):
         DbSession.add(ErrorFatality(error_name='info'))
     if not ErrorFatality.exists(error_name='warning'):
         DbSession.add(ErrorFatality(error_name='warning'))
     if not ErrorFatality.exists(error_name='error'):
         DbSession.add(ErrorFatality(error_name='error'))
     if not ErrorFatality.exists(error_name='severe'):
         DbSession.add(ErrorFatality(error_name='severe'))
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:9,代碼來源:youtube_model.py

示例5: get_duration_of_videos_per_youtuber

 def get_duration_of_videos_per_youtuber():
     return DbSession.query(func.sum(Video.duration), Youtuber.channel_title).filter(and_(Video.type.isnot(VideoType.EXISTING.video_type_id)), Video.stored.is_(True)).join(Youtuber).group_by(Video.channel_id).all()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:2,代碼來源:youtube_model.py

示例6: create_without_transaction

 def create_without_transaction(cls, **kwargs):
     instance = cls(**kwargs)
     DbSession.add(instance)
     return instance
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:4,代碼來源:mixins.py

示例7: get_number

 def get_number(cls):
     return DbSession.query(cls).count()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:2,代碼來源:mixins.py

示例8: load_all

 def load_all(cls, **kwargs):
     q = DbSession.query(cls)
     filters = [getattr(cls, field_name) == kwargs[field_name] for field_name in kwargs]
     return q.filter(and_(*filters)).all()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:4,代碼來源:mixins.py

示例9: save_to_delete

 def save_to_delete(self):
     video_part = self.type == DownloadFlag.CRAWLED or self.type == DownloadFlag.SCHEDULED
     audio_part = DbSession.query(Audio).filter(Audio.video_id == self.video_id)
     playlist_item_part = PlaylistItem.exists(video_id=self.video_id)
     return not (audio_part and video_part and playlist_item_part)
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:5,代碼來源:youtube_model.py

示例10: load_with_youtuber

 def load_with_youtuber():
     return DbSession.query(Profile, Youtuber).join(YoutuberInProfile).join(Youtuber).all()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:2,代碼來源:youtube_model.py

示例11: delete_audio_file

 def delete_audio_file(self):
     full_path = self.absolute_path
     DbSession.delete(self)
     if os.path.isfile(full_path):
         os.remove(full_path)
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:5,代碼來源:youtube_model.py

示例12: get_single_statistic

 def get_single_statistic(channel_id, video_type):
     return DbSession.query(Statistic).filter(
         and_(Statistic.channel_id == channel_id, Statistic.video_type == video_type)).one()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:3,代碼來源:youtube_model.py

示例13: get_videos_after_time_stamp

 def get_videos_after_time_stamp(time_stamp):
     all_video_queue = DbSession.query(VideoQueueItem).options(Load(Video).load_only('video_id')).all()
     actual_list = [video.video_id for video in all_video_queue]
     return DbSession.query(VideoQueueItem, Video, Youtuber, VideoType, PlaylistItem, Playlist).filter(
         and_(Video.video_id.in_(actual_list), Video.downloaded_date > datetime.datetime.fromtimestamp(int(time_stamp)/1000))).order_by(
         Video.downloaded_date).all()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:6,代碼來源:youtube_model.py

示例14: get_whole_video_queue_obj

 def get_whole_video_queue_obj():
     return DbSession.query(VideoQueueItem, Video, Youtuber, VideoType, PlaylistItem, Playlist).join(Video).join(Youtuber).join(VideoType)\
         .outerjoin(PlaylistItem).outerjoin(Playlist).order_by(asc(Video.downloaded_date)).all()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:3,代碼來源:youtube_model.py

示例15: get_pending_converted_videos_by_channel_id

 def get_pending_converted_videos_by_channel_id(channel_id):
     return DbSession.query(Video).filter(and_(Video.to_be_converted.is_(True), Video.channel_id == channel_id)).all()
開發者ID:Sheldan,項目名稱:yt_crawler,代碼行數:2,代碼來源:youtube_model.py


注:本文中的yt_crawler.backend.database.DbSession類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。