本文整理匯總了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
示例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]
示例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)
示例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'))
示例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()
示例6: create_without_transaction
def create_without_transaction(cls, **kwargs):
instance = cls(**kwargs)
DbSession.add(instance)
return instance
示例7: get_number
def get_number(cls):
return DbSession.query(cls).count()
示例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()
示例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)
示例10: load_with_youtuber
def load_with_youtuber():
return DbSession.query(Profile, Youtuber).join(YoutuberInProfile).join(Youtuber).all()
示例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)
示例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()
示例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()
示例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()
示例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()