需求

前段时间面试,被问到设计模式。说实话虽然了解面向对象、多态,但突然被问到设计模式,还要说清解决什么问题,自己是有些懵的,毕竟实习主要工作是在原项目基础进行CRUD,自己还是没有深度思考,所以只能简单介绍自己知道的简单工厂模式等。趁着回家这段假期,充电学习一下Go设计模式!

学习资料

B站搜索一下,突然发现刘丹冰老师更新了设计模式课程。因为前面学习Go基础也是通过书籍和刘丹冰老师的视频学习。
设计模式链接如下:

  • https://www.bilibili.com/video/BV1Eg411m7rV

由于家里网络和个人学习习惯,喜欢把视频下载下来学习,会更专注下来。
上次下载忘了写博客,这次专门记录一下,方便下次操作。

问题

you-get是下载利器,然而bilibili的合集下载会有些问题,具体原因没有仔细分析,个人怀疑是获取不了合集下的所有视频链接。所以本文通过八爪鱼进行获取视频链接,再通过python写脚本,you-get下载全部视频。

工具准备

个人是Mac电脑,具体软件或环境:

  • 八爪鱼软件
  • Python 3.8.9, 安装pandas包
  • you-get
    (以上环境都是以往安装的,网上也有不错的安装教程,这里就不赘述了。)

下载步骤1. 八爪鱼将合集视屏的链接收集起来并下载

软件操作比较简单,主要步骤:

  • 建立新任务,即添加链接,点击开始采集
  • 根据网页分析结果进行采集和保存
  • 导出采集的视频链接数据为excel

2. 对合集中所有视频链接进行读取和you-get下载

excel命名为bilibili.xlsx
下面是简单的脚本下载

#-- coding: utf-8 --#  下载bilibili合集视屏# 首先八爪鱼爬取网页所有视频地址,保存到excel# 然后python读取excel文件,到字典中# 最后循环便利,使用you-get下载import pandas as pdimport osdef readExcel(file):    df = pd.read_excel(file, sheet_name = "Sheet1") # sheet_name不指定时默认返回全表数据    return df["title"]  # 返回表格中title列,此列存放视频的地址def download(address): # 下载    print(address) # 测试    for i in address:        print("-------")        os.system("you-get -o ./bilibili "+ str(i)) # -o后面是保存路径,根据个人需求更改if __name__ == "__main__":    file_path = r"./bilibili.xlsx"    videos = readExcel(file_path)    download(videos)

总结

解决方案比较简单,也没考虑太多的优化。暂时够用,若有更好改进,欢迎评论和指出!