2

我制作了这个小脚本来处理我商店销售点的 CSV 导出。它需要我们的条码扫描仪输入的条码列表。然后在列表中查找这些项目,以根据我们拥有的销售点要求快速检查我们的实物库存。

它有效......我很好奇的是,如果我可以将 raw_input 从它默认使用的 ENTER 更改为 TAB 并替换它?

我的条形码扫描仪被编程为在扫描条形码后使用 TAB(正如我们的 POS 要求的那样),这样在扫描物品时不必手动操作键盘会非常方便。

可能吗?

import csv

inv = csv.reader(open('onhand.tab', 'rU'), dialect='excel-tab', delimiter="\t")

invarray = []
countlist = []

for row in inv:
    invarray.append(row)

print "Input barcode followed by <ENTER>. When finished, 'x' followed by <ENTER>"
while True:
    bb = raw_input('> ')
    countlist.append(bb)
    if bb == 'x':
        break

print "\n" * 100
print "+" + "-" * 130 + "+"

for row in invarray:
    barcode = row[0]
    prod_name = row[8]
    main = row[4]
    vb = row[12]
    oo = row[6]
    toh = row[9]
    mnum = row[5]

    for row in countlist:
        bc = row[0]
        if bc == barcode:
            print ('|%-15s\t%-100s\t%-3s|') % (barcode, prod_name, main)
            print "+" + "-" * 130 + "+"
4

1 回答 1

4

你不能; raw_input()仅在输入后才返回控制权ENTER

直接从直接读取sys.stdin

barcode = []
while True:
    char = sys.stdin.read(1)  # read 1 character from stdin
    if char == '\t':  # if a tab was read
        break
    barcode.append(char)
countlist.append(''.join(barcode))
于 2013-09-29T22:59:15.560 回答