python实现超市扫码仪计费

作者:_从未止步 时间:2023-01-11 03:53:31 

python实现超市扫码仪计费的程序主要是使用超市扫码仪扫商品的条形码,读取商品信息,实现计费功能。主要用到的技术是串口通信,数据库的操作,需要的环境包括:python环境,mysql,python库(serial,MySQLdb)等等。

这个程序的主要过程是:使用扫码仪扫描商品条形码,通过串口通信获取商品条形码,通过该条形码获取商品信息,显示该商品信息并统计总费用。其中商品信息保存在数据库中,可事先导入或者手动导入商品信息,而我的在这里是事先导入的(也可以边扫边倒入信息),导入到数据库中的信息如下:

python实现超市扫码仪计费

程序代码如下:


#coding:utf8

import serial
import MySQLdb

ser = serial.Serial('COM5',9600)

#获取一行信息
def recv(serial):
data = ''
while serial.inWaiting() > 0:
 data += serial.read(1)

return data

def GetInfo(db,data):
data = data[0:-1] #最后面有一个空格,需要去掉,否则会影响读数据库
print data
ret = 0.0
try:
 cur = db.cursor()
 sql="set names utf8" #这一条语句是告诉数据库编码方式为 utf8
 cur.execute(sql)

sql = "select * from productinfo where code=%s"%(data)
 #print sql
 cur.execute(sql)
 #sql = "select * from productinfo where(code=%s)"
 #cur.execute(sql,data)  
 results = cur.fetchall()
 #print results
 for row in results:
  code = row[0]
  #print code
  price = row[1]
  #print price
  info = row[2]
  #print info
  ret = price
  #解析出来的信息可能为中文,直接print肯定是不行的,需要转化为windows下的GBK编码
  print 'coding=',row[0],'price=',row[1],'info=',info.decode('UTF-8').encode('GBK')    
except:
 print 'it has no infomation about %s'%(data)

return ret

db = MySQLdb.connect('localhost','root','',"zou",3306,'utf8')
cursor = db.cursor()

#cursor.execute("DROP TABLE IF EXISTS productinfo")

'''''
sql="""CREATE TABLE productinfo(
 code CHAR(18),
 price double(9,2),
 info CHAR(25))"""
cursor.execute(sql)
'''

sum = 0.0  
while True:
data = recv(ser)
if data != '':
 #print data
 sum += GetInfo(db,data)
 print '总付款:',sum

db.close()
ser.close()

由于刚刚开始学习python,所以代码规范上做的还不是很好,希望大家多多指出,最后程序的运行如下:

python实现超市扫码仪计费

其中我的程序中可以使用中文(刚刚开始不是显示?就是显示乱码),这个问题我在前面的博客中谈论过,需要处理数据库以及从数据库读取的数据的编码方式。若是大家看出什么错误或是有意见的话,欢饮大家留言。

来源:https://blog.csdn.net/zr1076311296/article/details/51759480

标签:python,扫码仪
0
投稿

猜你喜欢

  • 一种简单的ID生成策略: Mysql表生成全局唯一ID的实现

    2024-01-25 09:55:41
  • Selenium定时刷新网页的实现代码

    2021-09-30 04:01:00
  • Navicat Premium15连接云服务器中的数据库问题及遇到坑

    2024-01-19 05:41:50
  • Python队列RabbitMQ 使用方法实例记录

    2021-01-30 22:38:26
  • MySQL性能优化的最佳20+条经验

    2024-01-27 15:25:06
  • pandas实现手机号号码中间4位匿名化的示例代码

    2022-02-02 06:08:40
  • 解决Go gorm踩过的坑

    2024-04-25 15:30:06
  • CSS教程:简单理解em

    2008-07-03 12:44:00
  • 基于python实现数组格式参数加密计算

    2021-08-20 23:29:54
  • Python类属性的延迟计算

    2023-07-22 15:50:33
  • Selenium执行完毕未关闭chromedriver/geckodriver进程的解决办法(java版+python版)

    2023-03-28 12:39:51
  • python使用分治法实现求解最大值的方法

    2021-07-14 12:06:09
  • 使用python从三个角度解决josephus问题的方法

    2022-02-22 02:19:55
  • 利用Python操作excel表格的完美指南

    2022-05-21 07:59:09
  • Python实现完整的事务操作示例

    2023-11-15 21:02:02
  • php预定义常量

    2023-11-14 10:35:27
  • Windows中使用wxPython和py2exe开发Python的GUI程序的实例教程

    2021-07-07 08:52:17
  • JS操作Cookie写入和读取实例代码

    2024-04-22 13:07:30
  • Mysql Innodb存储引擎之索引与算法

    2024-01-18 02:09:39
  • Python 添加文件注释和函数注释操作

    2021-07-23 07:16:54
  • asp之家 网络编程 m.aspxhome.com