这是我在我的Raspberry Pi上使用RFID wiegand阅读器的代码片段。
def main():
set_procname("Wiegand Reader")
global bits
global timeout
GPIO.add_event_detect(D0, GPIO.FALLING, callback=one)
GPIO.add_event_detect(D1, GPIO.FALLING, callback=zero)
GPIO.add_event_detect(S1, GPIO.FALLING, callback=unlockDoor)
while 1:
if bits:
timeout = timeout -1
time.sleep(0.001)
if len(bits) > 1 and timeout == 0:
#print "Binary:", int(str(bits),2)
c1 = int(str(bits),2)
result = ((~c1) >> 1) & 0x0FFFFFF;
checkAccess(result, doorID)
else:
time.sleep(0.001)
if __name__ == '__main__':
main()
在普通的USB RFID阅读器上,我收到了0000119994以及卡上印刷的内容。但是使用这段代码它会读取119994.我已经尝试了多张卡片。它总是在前面掉落零。
我甚至尝试过一张零卡片。 0000120368,显示120368 我以为它取消了前4个字符,但后来我尝试了一个前面只有3个零的钥匙扣。 0004876298,它读取4876298.只丢掉前面的零。
答案 0 :(得分:1)
>>> a = 0003
>>> a
3
>>> b = 0b0011
>>> bin(b)
0b11
据我所知,所有RFID都有10个数字。您可以创建一个简单的程序来添加这些数字并将值存储为字符串:
def rfid_formatter(value):
str_value = str(value)
for s in range(10 - len(str_value)):
str_value = "0" + str_value
return str_value
您的测试用例:
print rfid_formatter(120368)
print "0000120368"
print rfid_formatter(4876298)
print "0004876298"
答案 1 :(得分:1)
如上所述,前导零以二进制序列删除,当您使用int()
将字符串显式转换为十进制时也是如此。
还没有提到的是,在Python 2.x中,带前导零的整数被视为八进制值。
>>> a = 0003
>>> a
3
>>> a = 000127
>>> a
87
由于这引起了混淆,因此在Python 3中删除了隐式八进制转换,并且数值中任意数量的前导零将引发SyntaxError
。
>>> a = 000127
File "<stdin>", line 1
a = 000127
^
SyntaxError: invalid token
>>>
您可以在PEP 3127中阅读这些决定背后的理由。
无论如何,我提到所有这一切只是为了得出一个假设:你可能不使用八进制表示。相反,我认为您正在将result
转换为checkAccess
中的字符串,以便您可以进行字符串比较。如果这个假设是正确的,你可以简单地使用字符串方法zfill
(零填充):
>>> str(119994).zfill(10)
'0000119994'
>>>
>>> str(4876298).zfill(10)
'0004876298'
>>>