pyqt5 商店小票打印的实现模板

说明

最近在用pyqt5做商店小票打印,用的是得力DL-581PW(NEW)热敏小票打印机。

商店小票打印,属于escpos打印。

在网上找了很多实现方法,看了很多相关文章,经历了很多困难,最后终于实现了。

这里先分享一下我看过的文章和尝试过的方法,最后分享我的实现套路。

一.使用execl打印

很多场景,我都是使用win32com模块的execl打印,基本能解决大部分的打印问题。(相关的方法网上也有,可以找找,如有需要,我有时间单独写一篇)

但使用execl打印热敏小票却不行,会打出整页空白,此路不通,只能放弃。

二. 使用QTextDocument打印

pyqt5自带一套打印工具,也颇为好用。

商店小票,一般思路就是使用QTextDocument,对其setHtml,便能利用html进行排版打印。

这种方法网上很多,但是依然有问题,就是QTextDocument会强制左边和顶部留白。

这里我主要参考了《PyQt5中使用Qprinter打印热敏小票》一文,大家可以进去看看,非常好的文章。

三 使用ESCPOS打印

热敏小票打印机,都是遵循escpos指令进行打印的,所以我便去找python的escpos模块,还真有。

一个叫python-escpos,使用命令pip install python-escpos即可安装。
一个叫python-printer-escpos, 使用命令pip install python-printer-escpos即可安装。

这两个模块,都需要先连接打印机。但我搞了半天,也没有连上,只能放弃。
相关文章,网上也有,自行搜索吧。

四. HTML文件转图片,进行打印

回到《PyQt5中使用Qprinter打印热敏小票》一文,推荐了html转图片打印的方法,最终作者就是用这种方法实现的。

这种方法,也算解决了QTextDocument强制留白的问题。

我也尝试了一下,但html转图片太过麻烦,而且打印效果不清晰,选择放弃。

五. 使用QWebEngineView进行打印

基于《PyQt5中使用Qprinter打印热敏小票》一文,继续研究,继续摸索,终于找了我的实现方法,直接使用QWebEngineView进行打印,简单方便。

但有一点缺陷,就是打印效果依旧有点不清晰,后面就通过字体加粗加大来对冲解决。

【如下代码,完全复制,直接运行,即可使用】

import win32print
from PyQt5.QtWidgets import QApplication, QDialog
from PyQt5.QtCore import QObject, pyqtSlot, QUrl, QSizeF, QMarginsF, QTimer
from PyQt5.QtWebEngineWidgets import QWebEngineView
from PyQt5.QtPrintSupport import QPrinter
import sys


################################################
the_html='''
<!-- webprint.html -->
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用PyQt5打印热敏小票</title>
</head>
<style type="text/css">
    * {padding:0;margin: 0;font-weight:bold;face="KaiTi"}
    h1 {font-size: 1em}
    h3 {text-align: center;font-size: 2em}
    .left {float: left;}
    .right {float:right;}
    .clearfix {clear: both;}
    .print_container {width: 180px;}
    .section2 label {font-size: 1em;display: block}
    .section3 label {font-size: 1em;display: block}
    .section4 .total label {font-size: 1em;display: block}
    .section4 {text-align: center;font-size: 1em;border-bottom: 1em solid #DADADA}
    .section5 label {text-align: center;font-size: 1em;display: block}
</style>
<body>
<div id="capture">
    <div class="print_container">
        <h3>一心狮便利店</h3>
        <span>***************************************</span>
        <div class="section3">
            <label>订单号:700001001201811161631123558</label>
            <label>下单时间:2018-10-16 16:31:14</label>
            <label>收银员:王小明</label>
        </div>
        <span>***************************************</span>
        <div class="section4">
            <div style="border-bottom: 3px solid #DADADA;">
                <table style="width: 180;">
                    <thead>
                    <tr>
                        <td width="110">商品名</td>
                        <td width="40">单价</td>
                        <td width="30">数量</td>

                    </tr>
                    </thead>
                    <tbody>
                    <tr>
                        <td>今麦郎1</td>
                        <td>100</td>
                        <td>10000.00</td>
                    </tr>
                    <tr>
                        <td>今麦郎2</td>
                        <td>1</td>
                        <td>100.00</td>
                    </tr>
                    <tr>
                        <td>今麦郎3</td>
                        <td>1</td>
                        <td>100.00</td>
                    </tr>
                    </tbody>
                </table>
            </div>
            <div class="total">
                <label class="left">合 计</label>
                <label class="right">100.00</label>
                <div class="clearfix"></div>
                <label class="left">收款金额</label>
                <label class="right">100</label>
                <div class="clearfix"></div>
                <label class="left">找零金额</label>
                <label class="right">0.00</label>
                <div class="clearfix"></div>
            </div>
            <div style="text-align: centre;">
                <label>顾客已付款</label>
            </div>
            <span>***************************************</span>
        </div>
        <div class="section5">
            <label>电话:</label>
        </div>
        <span>***************************************</span>
        <div class="section5">
            <label>欢迎光临,谢谢惠顾!</label>
            <label>一心狮便利店</label>
            
        </div>
        <div align="center" class="section5">
              <br />
              <img src='http://c.biancheng.net/cpp/templets/new/images/logo.jpg?v=3.994' align="middle" width="130" height="130"/>
              <div class="clearfix"></div>
              <br />
              <label>微信扫码 购好物 享服务</label>
        </div> 
        
    </div>
    
</div>

</body>
</html>
'''

################################################
# 打印回调函数
def print_completed(result):
    pass

# 开始打印小票
def goto_print_litbill():
    webview.page().print(printer, print_completed)


################################################
#######程序入口
################################################
if  __name__ == '__main__':
    app = QApplication(sys.argv)
    webview = QWebEngineView()
    webview.setHtml(the_html)
    #webview.show()
    win32print.SetDefaultPrinter("DL-581PW(NEW)")  #设置为默认打印机
    printer = QPrinter()
    printer.setPageSizeMM(QSizeF(80, 300))
    ##########必须延迟打印,否则网页还没加载,打印空白#########
    timer = QTimer()
    timer.timeout.connect(goto_print_litbill)
    timer.setSingleShot(True)
    timer.start(500)
    ###################################################
    sys.exit(app.exec_())

本文如有帮助,敬请留言鼓励。
本文如有错误,敬请留言改进。

写在最后1

我自己现在用的就是【五. 使用QWebEngineView】进行打印,但不代表其他方法完全不可行,大家根据自己情况自己摸索下。

当然,这种方法依旧存在打印不清晰的缺陷,如果哪位大神有更好的方法,敬请留言推荐,谢谢了。

写在最后2

最后,郑重感谢《PyQt5中使用Qprinter打印热敏小票》的作者yuchanns

有了他这篇文章,节省了我好多时间。本文本想收费的,嘿嘿,为感谢yuchanns,就免费分享了,希望也能节省你的时间。如果本文对你有帮助,也请去感谢他吧。

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值