-1

我想使用带有树莓派的热敏打印机。我想从 mysql 数据库接收打印机供应商 ID 和产品 ID。我的列是varchar.

我的代码是

import MySQLdb
from escpos.printer import Usb
db= MySQLdb.connect(host=HOST, port=PORT,user=USER, passwd=PASSWORD, db=database)
cursor = db.cursor()
sql = ("select * from printerdetails")
cursor.execute(sql)
result = cursor.fetchall()
db.close()
for row in result:
    printer_vendor_id = row[2]
    printer_product_id = row[3]
    input_end_point = row[4]
    output_end_point = row[5]
print printer_vendor_id,printer_product_id,input_end_point,output_end_point
Printer = Usb(printer_vendor_id,printer_product_id,0,input_end_point,output_end_point)
Printer.text("Hello World")
Printer.cut()

但它不起作用。id 是字符串。打印命令显示 0x154f 0x0517 0x82 0x02.in my case

Printer = Usb(0x154f,0x0517,0,0x82,0x02)

工作正常。我如何将相同的 id 存储到数据库中并使用它们来配置打印机

4

1 回答 1

1

你的问题是你的电话Usb是期待整数,如果你这样称呼它就可以了

Printer = Usb(0x154f,0x0517,0,0x82,0x02)

但是您的数据库调用返回存储为字符串的十六进制值的元组。因此,您需要将这些字符串转换为整数,如下所示:

for row in result:
    printer_vendor_id = int(row[2],16)
    printer_product_id = int(row[3],16)
    input_end_point = int(row[4],16)
    output_end_point = int(row[5],16)

现在如果你这样做

print printer_vendor_id,printer_product_id,input_end_point,output_end_point

你会得到

(5455, 1303, 130, 2)

这可能看起来不对,但不是,您可以通过要求以十六进制格式显示整数来检查:

print ','.join('0x{0:04x}'.format(i) for i in (printer_vendor_id,printer_product_id,input_end_point,output_end_point))

0x154f,0x0517,0x0082,0x0002

我应该指出,这只有效,因为您的数据库表只包含一行。for row in result循环遍历表中的所有行,但恰好只有一个,这没关系。如果还有更多,您的代码将始终获取表的最后一行,因为它不检查行的标识符,因此会重复为相同的变量赋值,直到数据用完。

where解决这个问题的方法是在 SQLselect语句中添加一个子句。就像是

"select * from printerdetails where id = '{0}'".format(printer_id)

现在,因为我不知道您的数据库表是什么样的,所以列名id几乎肯定是错误的。而且很可能是数据类型:它很可能不是字符串。

于 2018-04-04T13:03:21.637 回答