/QzoneExporter

QQ空间爬虫,可导出并显示日志、相册、留言板、说说、照片、视频等数据。

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

QzoneExporter

QQ空间数据导出及显示。

  • 导出日志、留言板、相册、说说等数据。
  • 将说说、相册中的图片及视频下载至本地。
  • 以网页形式显示本地数据,可在浏览时自动下载图片及视频。
  • 支持 Exif 信息写回照片,时间写入文件名。(由Yang-zgreysign提供)

导出数据

usage: exporter.py [-h] [--blog] [--msgboard] [--photo] [--shuoshuo] [--like]
                   [--download] [--all]

optional arguments:
  -h, --help  show this help message and exit
  --blog      导出日志数据
  --msgboard  导出留言板数据
  --photo     导出相册数据
  --shuoshuo  导出说说数据
  --download  下载图片或视频至本地
  --all       导出所有数据

显示数据

usage: displayer.py [-h] [--download]

optional arguments:
  -h, --help  show this help message and exit
  --download  当本地不存在图片、视频时,尝试下载至本地

输入

  • target_uin 需要导出数据的QQ号。
  • self_uin 用于登录空间的QQ号。
  • cookies_value 从浏览器登录QQ空间,按 F12,点击 Network 选项卡,点击QQ空间“我的主页“,点击 XHR,点击 main_page_cgi 请求,从 Header 中找出 cookie,如图所示。
  • g_tk 可通过 cookies_value 中的 p_skey 计算,选填。 获取g_tk及cookie

登录QQ需要有访问目标QQ空间的权限。

网页显示效果

预览

预览

日志

blog

blog

留言板

msgboard

相册

photo

photo

photo

说说

shuoshuo

输出文件

target_uin/
    blog/
        日志分类/             // 譬如:个人日志
            日志正文.html
            日志评论.json
    msg_board/
        每20条留言分为1个json文件
    photo
        相册名_相册id/
            downloaded/       // 保存下载的数据
            照片数据
            评论数据
        相册信息.json
        downloaded.txt        // 已下载的url
        to_download.txt       // 待下载的url及文件名
    shuoshuo/
        downloaded/
        downloaded.txt
        to_download.txt
        shuoshuo_tid.txt      // 保存说说的tid
        每40条说说分为1个json文件
    main_page.json            // 日志、相册、说说的数量
    like_information.json     // 保存点赞数据

日志

blog

blog

留言板

msgboard

相册

photo

photo

说说

shuoshuo

说明

  • 数据以json格式保存,可通过网页显示主要数据。
  • 导出的数据是登录账号可见的数据,“仅主人可见”等数据无法获取。
  • 导出的视频链接有时效性,超时无法访问。
  • 如果相册图片数量较多并且未下载至本地时,网页显示会比较慢。

依赖

  • requests
  • bs4
  • Python ≥ 3.6
  • piexif(Exif 信息写回)
  • Flask(网页显示)

使用

# exporter.py
# 根据需要设定以下变量
target_uin = "需要导出数据的QQ号"
self_uin = "登录空间的QQ号"
cookies_value = "从浏览器获取"
g_tk = "从浏览器获取"   # 可选,会尝试通过 cookies 计算
q = QzoneExporter(self_uin, g_tk, cookies_value, args, target_uin)
q.export()

示例

导出日志数据

命令行中运行

python exporter.py --blog

下载相册照片

python exporter.py --photo
python exporter.py --download

python exporter.py --photo --download

网页显示

python displayer.py [--download]

Exif 信息写回照片

具体使用参考 photo_exif_recover.py 内的说明。

存在的问题

  • 某些图片通过sharpP格式传输,无法打开。
  • 进度的保存。
  • 由于数据未抓取到本地、不想写等原因,网页显示时忽略了一些无关紧要的数据。
  • 未能完全测试所有情况,因此网页显示时可能会出现某些错误。

更新记录

  • 2019.05.10 支持网页显示;使用多线程下载,去掉超时设置;去掉点赞数据的抓取;修复了文件名可能非法的问题。

参考

LICENSE

GPL-3.0,额外条件:禁止商用。

捐赠

如果您认为该项目在一定程度上帮助了您,可以赞赏我:D

赞赏码