打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
使用python代码实现 PDF 阅读器

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理

本文章来自腾讯云 作者:Python进阶者

想要学习Python?有问题得不到第一时间解决?来看看这里“1039649593”满足你的需求,资料都已经上传至文件中,可以自行下载!还有海量最新2020python学习资料。
点击查看



书籍

使用 Book 类来保存书籍信息,比如元数据、页数以及阅读与否的信息。通过 eq 特殊方法,来判断两个 book 实例是否为同一对象。

class Book:    def __init__(self, fname):        # 文件名        self.fname = fname        # 是否被阅读        self.flag = None        self._info = None        self._page = 0        self.get_meta_data(self.fname)    def __eq__(self, other):        if hasattr(other, 'fname'):            return self.fname == other.fname        return False    

 

同时阅读


通过内部维护一个 read_list 列表来实现同时阅读多本书。列表储存 book 对象,每个 book 对象都有一个 page 属性。这样,我们的程序就能记住每本书被翻到的页数了。

第二行代码,是对 read_list 进行初始化。book.flag 用来判断这本书上次关闭前是否处于阅读的状态。如果是,我们就把它放在阅读列表中。

self.read_list = [None]self.read_list.extend(book for book in self.booklist if book.flag)

 

左键翻页
我们重写 MyArea 类的 mousePressEvent 方法。event.pos() 函数用来获取鼠标的坐标,x() 用来获取横坐标。

width 为 MyArea 区域的宽度,如果点击鼠标左键,且鼠标位置的横坐标小于 1/3 区域宽度,那么向前翻页;大于 2/3 区域宽度,那么向后翻页。

# 鼠标左键翻页def mousePressEvent(self, event):    pos = event.pos().x()    width = self.size().width()    if event.button() == Qt.LeftButton:        if pos > width * 2 / 3:            self.right()        elif pos < width / 3:            self.left()sqlite3

 

sqlite3 是轻量型本地数据库,具有无服务器、零配置、速度快等特点。

PyReadon 启动时,会从数据库中读取图书信息。read_db 函数主要执行以下功能:

如果路径中不存在 PDF.db 数据库,那么就新建 PDF.db 数据库,并且创建一个 book_info 表格,该表格拥有三个属性 path, page, flag;

从 book_info 表格中读取数据,并创建 book 对象来接收这些数据,最后通过 yield 函数返回 book 对象。

book_db = 'PDF.db'book_info = namedtuple('info',  'path page flag')def read_db():    # 将路径更改为该文件所处路径    os.chdir(os.path.dirname(os.path.realpath(__file__)))    if not os.path.exists(book_db):        conn = sqlite3.connect(book_db)        conn.execute("CREATE TABLE book_info(path, page, flag)")        conn.close()    conn = sqlite3.connect(book_db)    for row in conn.execute('SELECT * FROM book_info'):        info = book_info(*row)        book = Book(info.path)        book.page = info.page        book.flag = info.flag        yield book    conn.close()  

 

将数据存储到数据库中:

将书籍列表传给 save2db 函数,通过列表推导式创建 book 所在地址的列表。conn.executemany 函数将迭代生成器表达式,并获得 书籍地址、阅读页数、是否在阅读列表中 等信息,最后将这些信息存储在数据库中。

def save2db(booklist):    conn = sqlite3.connect(book_db)    conn.executemany("INSERT INTO book_info Values (?,?,?)",                ((book.fname, book.page, book.flag) for book in booklist))    conn.commit()    conn.close()

 

在进行存储数据之前,我们首先要将 book_info 数据库中的内容清空。

def remove_db():    conn = sqlite3.connect(book_db)    conn.execute('DELETE FROM book_info')    conn.commit()    conn.close()

 

查看书籍信息


书籍支持查看右键菜单,我们使用 QMessageBox.about 函数来显示书籍信息。

elif action == item3:    index = row_num * 8   col_num    # 之后改成 book    book = self.booklist[index]    info = book.info    fmt = f'路径:{info.path}\n\n'         f'格式:{info.format}\n\n'         f'标题:{info.title}\n\n'         f'作者:{info.author}\n\n'         f'Creator:{info.creator}\n\n'         f'Producer:{info.producer}\n\n'    QMessageBox.about(self, '文档信息', fmt)

 

弹窗

通过 Qt Designer 设计了一个弹窗,并与主程序绑定:

info 即为弹窗,点击工具栏中的信息栏时会弹出窗口。

info = Info()reader.infobar.triggered.connect(info.show)

 

来源:https://www.icode9.com/content-1-827051.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
Sqlite—Python接口
转:Python操作SQLServer示例
Python标准库14 数据库 (sqlite3)
python操作sqlite示例(支持多进程/线程同时操作) - 学步园
YYDS! Python 帮我扛起运营大旗!
SQLite和Excel操作
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服