利用AI Chat 将电子书自动截屏并保存成pdf文件

电子书如果要下载下来,无非就两种类型的方法,一种是从内部破解,通常是某些极客将软件破解成免费版,但是风险也大。另一种是从外部破解,就是截屏保存,然后将所有图片拼成pdf文件。

如果要将整本电子书截屏保存,那么截屏的动作重复度极高。计算机不就是擅长做重复性的动作,那么只要让计算机:

截屏
保存
下一页
是否结束
保存成PDF

一直重复这个动作,知道满足条件后保存成PDF文件,
理论成立,便可实践
作为一个开发能力不强,代码能力不强的小白,纯靠手搓的话,头发都会秃掉。最近ChatGPT等AI Chat 很火,而且很智能,能够回答我们大部分的问题。我最近也在用百度的文心一言,挺好用的,大大减少了我检索的时间,以至于后面我要实践的内容,也是通过文心一言辅助我完成。

  1. 既然需要用电脑操作,那么我们就需要将手机或平板上的内容进行投屏
    市面上的投屏工具普遍需要VIP才能投屏,显然不符合我白嫖的性格,通过文心一言搜索:用开源的工具将手机屏幕通过数据线投影到电脑上(问问题的方式真的很重要,不然就给你推荐一些需要付费的投屏软件),接下来我会通过问AI问题的形式 ,实现将电子书自动截屏并保存成pdf文件这个功能。既然是AI回答问题,那么不同的时间不同的场景问相同的问题得到的答案是不一样的
    利用AI Chat 将电子书自动截屏并保存成pdf文件_第1张图片
    于是就给我介绍了scrcpy,作为一个用爱发电的作者,这么好用的工具我肯定不会藏着掖着,这个通过问问题可是很难找到答案的,链接奉上: scrcpy-手机投屏到电脑<–这里面有下载和如何使用scrcpy的教程

  2. 如何用python去控制键盘和鼠标,不知道的话可以问问AI
    利用AI Chat 将电子书自动截屏并保存成pdf文件_第2张图片

import pyautogui  
  
# 移动鼠标到屏幕的(100, 100)坐标处  
pyautogui.moveTo(100, 100, duration=0.25)  
  
# 点击鼠标左键  
pyautogui.click()  
  
# 输入文本  
pyautogui.write('Hello, world!', interval=0.25)  
  
# 按下键盘上的"Enter"键  
pyautogui.press('enter')

现在我们已经找到需要使用的pyautogui库了,既然这个库都能控制键盘和鼠标了,那问问pyautogui库能不能截屏
利用AI Chat 将电子书自动截屏并保存成pdf文件_第3张图片

import pyautogui  
  
# 截取屏幕并保存为图像文件  
screenshot = pyautogui.screenshot()  
screenshot.save('screenshot.png')

利用AI Chat 将电子书自动截屏并保存成pdf文件_第4张图片

import pyautogui  
  
# 截取屏幕中心1000x1000区域的截图,并保存为PNG格式的文件  
screenshot = pyautogui.screenshot(region=(0, 0, 1000, 1000))  
screenshot.save('screenshot.png')
  1. 截屏的话就需要指定区域截屏,多余的部分就挺多余的。我们都不知道要截多少才刚好,除非能定位鼠标的位置,所以再问问AI
    利用AI Chat 将电子书自动截屏并保存成pdf文件_第5张图片
import pyautogui  
  
# 获取鼠标当前位置  
mouse_position = pyautogui.position()  
  
print("鼠标当前位置:({0}, {1})".format(mouse_position[0], mouse_position[1]))
  1. 我们已经把截屏和保存的工作做完了,根据流程,我们需要通过按左右键进行前后翻页,那就再问问AI
    利用AI Chat 将电子书自动截屏并保存成pdf文件_第6张图片
    这样我们就能实现翻页的功能。
    然后一直重复该操作,直到截屏结束
  2. 如何将图片拼接成PDF文件呢
    利用AI Chat 将电子书自动截屏并保存成pdf文件_第7张图片
from PIL import Image  
  
# 打开图片文件  
image = Image.open('image.jpg')  
  
# 将图片保存为PDF文件  
image.save('output.pdf')

利用AI Chat 将电子书自动截屏并保存成pdf文件_第8张图片

from PIL import Image  
  
# 图片文件夹路径  
image_folder = r'F:\pdfscreenshot\inputscreenshot'  
# 获取图片文件夹中所有图片文件名  
image_files = [os.path.join(image_folder, f) for f in os.listdir(image_folder) if f.endswith('.jpg') or f.endswith('.png')]   
  
# 创建新的空白图片,大小与第一张图片相同  
images = [Image.open(file) for file in image_files]  
  
# 创建新的PDF文件并将图片添加到其中  
images[0].save('output.pdf', 'PDF', save_all=True, append_images=images[1:])
  1. 总结一下,AI Chat 可以大大的缩短我们检索的时间,同时也可以给我们提供更多的思路,但是却无法替代我们做完复杂的事情。这更像是造机器,AI Chat 不可能给我们造出符合我们需求的机器,只能给我们提供工具和零件,然后我们需要自己去设计和组装。
    利用AI Chat 将电子书自动截屏并保存成pdf文件_第9张图片

你可能感兴趣的:(python闲写,人工智能,pdf,python)