当前位置:Gxlcms > Python > python实现超市扫码仪计费

python实现超市扫码仪计费

时间:2021-07-01 10:21:17 帮助过:106人阅读

这篇文章主要为大家详细介绍了python实现超市扫码仪计费,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

程序代码如下:

  1. #coding:utf8
  2. import serial
  3. import MySQLdb
  4. ser = serial.Serial('COM5',9600)
  5. #获取一行信息
  6. def recv(serial):
  7. data = ''
  8. while serial.inWaiting() > 0:
  9. data += serial.read(1)
  10. return data
  11. def GetInfo(db,data):
  12. data = data[0:-1] #最后面有一个空格,需要去掉,否则会影响读数据库
  13. print data
  14. ret = 0.0
  15. try:
  16. cur = db.cursor()
  17. sql="set names utf8" #这一条语句是告诉数据库编码方式为 utf8
  18. cur.execute(sql)
  19. sql = "select * from productinfo where code=%s"%(data)
  20. #print sql
  21. cur.execute(sql)
  22. #sql = "select * from productinfo where(code=%s)"
  23. #cur.execute(sql,data)
  24. results = cur.fetchall()
  25. #print results
  26. for row in results:
  27. code = row[0]
  28. #print code
  29. price = row[1]
  30. #print price
  31. info = row[2]
  32. #print info
  33. ret = price
  34. #解析出来的信息可能为中文,直接print肯定是不行的,需要转化为windows下的GBK编码
  35. print 'coding=',row[0],'price=',row[1],'info=',info.decode('UTF-8').encode('GBK')
  36. except:
  37. print 'it has no infomation about %s'%(data)
  38. return ret
  39. db = MySQLdb.connect('localhost','root','',"zou",3306,'utf8')
  40. cursor = db.cursor()
  41. #cursor.execute("DROP TABLE IF EXISTS productinfo")
  42. '''''
  43. sql="""CREATE TABLE productinfo(
  44. code CHAR(18),
  45. price double(9,2),
  46. info CHAR(25))"""
  47. cursor.execute(sql)
  48. '''
  49. sum = 0.0
  50. while True:
  51. data = recv(ser)
  52. if data != '':
  53. #print data
  54. sum += GetInfo(db,data)
  55. print '总付款:',sum
  56. db.close()
  57. ser.close()

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

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

相关推荐:

Python实现计算圆周率π的值到任意位的方法示例

python实现简单淘宝秒杀功能

以上就是python实现超市扫码仪计费的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行