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

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

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

一直重复这个动作,知道满足条件后保存成PDF文件,
理论成立,便可实践

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

  1. 既然需要用电脑操作,那么我们就需要将手机或平板上的内容进行投屏

    市面上的投屏工具普遍需要VIP才能投屏,显然不符合我白嫖的性格,通过文心一言搜索:用开源的工具将手机屏幕通过数据线投影到电脑上 (问问题的方式真的很重要,不然就给你推荐一些需要付费的投屏软件),接下来我会通过问AI问题的形式 ,实现将电子书自动截屏并保存成pdf文件这个功能。既然是AI回答问题,那么不同的时间不同的场景问相同的问题得到的答案是不一样的

    于是就给我介绍了scrcpy,作为一个用爱发电的作者,这么好用的工具我肯定不会藏着掖着,这个通过问问题可是很难找到答案的,链接奉上: scrcpy-手机投屏到电脑<--这里面有下载和如何使用scrcpy的教程

  2. 如何用python去控制键盘和鼠标,不知道的话可以问问AI

python 复制代码
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库能不能截屏

python 复制代码
import pyautogui  
  
# 截取屏幕并保存为图像文件  
screenshot = pyautogui.screenshot()  
screenshot.save('screenshot.png')
python 复制代码
import pyautogui  
  
# 截取屏幕中心1000x1000区域的截图,并保存为PNG格式的文件  
screenshot = pyautogui.screenshot(region=(0, 0, 1000, 1000))  
screenshot.save('screenshot.png')
  1. 截屏的话就需要指定区域截屏,多余的部分就挺多余的。我们都不知道要截多少才刚好,除非能定位鼠标的位置,所以再问问AI
python 复制代码
import pyautogui  
  
# 获取鼠标当前位置  
mouse_position = pyautogui.position()  
  
print("鼠标当前位置:({0}, {1})".format(mouse_position[0], mouse_position[1]))
  1. 我们已经把截屏和保存的工作做完了,根据流程,我们需要通过按左右键进行前后翻页,那就再问问AI

    这样我们就能实现翻页的功能。
    然后一直重复该操作,直到截屏结束
  2. 如何将图片拼接成PDF文件呢
python 复制代码
from PIL import Image  
  
# 打开图片文件  
image = Image.open('image.jpg')  
  
# 将图片保存为PDF文件  
image.save('output.pdf')
python 复制代码
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 不可能给我们造出符合我们需求的机器,只能给我们提供工具和零件,然后我们需要自己去设计和组装。
相关推荐
m0_61360701几秒前
小土堆-P3-笔记
pytorch·python·深度学习
rgeshfgreh1 分钟前
Python高效开发:标准库与第三方库实战指南
python
十三画者2 分钟前
【文献分享】SpatialZ弥合从平面空间转录组学到三维细胞图谱之间的维度差距
人工智能·数据挖掘·数据分析·数据可视化
一条咸鱼_SaltyFish3 分钟前
[Day13] 微服务架构下的共享基础库设计:contract-common 模块实践
开发语言·人工智能·微服务·云原生·架构·ai编程
童欧巴3 分钟前
DeepSeek V4,定档春节
人工智能·aigc
爱学习的张大5 分钟前
深度学习中稀疏专家模型研究综述 A REVIEW OF SPARSE EXPERT MODELS IN DEEP LEARNING
人工智能·深度学习
虎冯河7 分钟前
阿里云 + 宝塔面板环境Python 项目从 0 到 1 部署全流
python·阿里云·云计算
爱打代码的小林10 分钟前
CNN 卷积神经网络 (MNIST 手写数字数据集的分类)
人工智能·分类·cnn
鹿衔`12 分钟前
PySpark 大规模造数任务优化与实施总结文档
python·pyspark
川西胖墩墩12 分钟前
游戏NPC的动态决策与情感模拟
人工智能