python实现超市扫码仪计费


本文摘自php中文网,作者不言,侵删。

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

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

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

程序代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

#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实现计算圆周率π的值到任意位的方法示例

python实现简单淘宝秒杀功能

以上就是python实现超市扫码仪计费的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

实例详解Python如何轻松实现动态进度条

range的用法介绍

人生苦短我用Python是什么梗

Python实现决策树算法

Python中k-近邻算法的原理与实现(附源码)

Python可以做什么工作

什么是Python返回函数?(实例解析)

Python file truncate() 方法是什么?能用在什么地方?

如何用Python计算圆周率?

Python可以做嵌入式吗

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...