最近在弄一个 Python 爬虫,碰到了二维码相关的问题。 爬取的网站可以用 QQ 扫码登录。一开始的想法是通过 selenium 获取屏幕截图然后用 zliblight 扫码解读出 URL, 然后再用这个 URL 通过 pyqrcode 生成一个二维码打印到终端上(主要是想只用终端来操作不用打开浏览器,所以采取的这个方案)。但是,扫描终端里的二维码却无法成功登录(手机 QQ 上显示登录成功但是网页端没有反应)。并且,在终端里打印出来的二维码与截图获取的二维码并不一样,虽然扫描之后得到 URL 是一样的,但是扫描截图里面的二维码就能够成功登录。有人了解这其中的原因嘛?或者,要如何生成和截图里完全一样的二维码打印到终端里?
获取二维码截图并打印终端版二维码的函数:
def print_qr(driver):
# Get QR code
path = os.path.join(BASE_DIR, "qrcode.png")
get_qr_screen_shot(driver, path)
# Load it to Pillow
with open(path, 'rb') as image_file:
image = Image.open(image_file)
image.load()
# decode it
codes = zbarlight.scan_codes('qrcode', image)
print(codes)
url = codes[0].decode('utf-8')
print(url)
# encode it in text and print it to terminal
qr = pyqrcode.create(url)
print(qr.terminal(quiet_zone=1))
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.