用以保存已爬取的id,避免重复爬取
用以保存当前任务爬取的id
用以保存下载失败的url
用以保存当前任务解析的url
核心代码,无任何纠错,因网站限制和网络波动基本不可能运行完成,仅供展示
带有简单GUI的主程序,输入的日期格式为(2020-01-01)
- 新增
file_type()
函数,对下载后的文件进行分类 - 新增
run_main()
函数,捕获连接失败异常并在异常后恢复id.txt
- 新增
rewrite()
函数,用以恢复id.txt
- 删除
file_type()
函数 get_href()
函数新增解析失败重新解析功能download
函数实现文件分类- 修改部分文字表述
- 这家网站有点小气,我只开5个协程去请求,每次请求完等待5秒,就这样他还是频繁给我报
HTTP:429 too many requests - please slow down...
- 但还算友好,毕竟是429,不是直接封我ip
- 全新改版 2.0
- 新增
sankaku_no_error.py
,核心代码,无任何纠错,因网站限制和网络波动基本不可能运行完成,仅供展示 - 将原本一个程序拆分为三步,需手动依次执行
- 原因在于网络不稳定性,某些时段请求网页经常连接超时,分三步更可控,减少不必要的重复执行
- 三步代码里都加入了大量试错,较为臃肿
- 删除exe文件夹,待以后整合优化再补上
- 新增
GUI.py
,赋予第一步:获取id.py
一个简单的图形界面
- 将
第二步:获取href.py
中的整体读写改成异步读写 get_href()
函数会在解析url的同时对all href.txt
、href.txt
、id.txt
做同步修改,即使中途出错中断也可以随时再次运行第二步直到解析完所有id第三步:下载.py
将不再下载超过20M的文件,那些多半是从小电影截取的片段,不好看还浪费时间- 学会把
\\
换成os.sep
,mac和win不用自己改了
第三步:下载.py
加入对href.txt
的实时修改,反复运行更顺畅
- 将旧文件扫进历史的垃圾堆
- 将原本的第一二三步用
class
封装起来塞进sankaku.py
并用tkinter
按钮触发运行 first()
会自动创建文本文件
- 对代码进行修修补补
class second
和class third
在运行上写了死循环,报错了会继续运行直到结束- 这个版本应该是比较好用了
- 打包了个exe
- 小修小补
- 创建一个 tkinter 的类,再把程序打包进线程,用线程驱动协程,小窗口不会在执行任务时未响应了
- 执行任务时禁用按钮
- 把
loop = asyncio.get_event_loop()
future = asyncio.ensure_future(self.main())
loop.run_until_complete(future)
- 替换为
asyncio.run(self.main())
- 小修小补
- 小修小补
- 最近实验得知,通过id解析出来的url是有时效性的,具体时长未知。过了时效再去打开这些url通通变成14.7k的sankaku logo
- 爬好的id可以存着,href及时下载
- 增加程序稳定性