Raspberry pi 2b+ 的超声波传感器会产生编译错误

Ultrasonic Sensors with Raspberry pi 2b+ creates compilation error

我设置了 3 个 HC-SR04 超声波传感器以 raspberry pi 连续运行。两个传感器工作正常,而一个非常不一致。我多次更换了电线、传感器和面包板,还更换了与传感器相关的触发和回波引脚。我已经调试了代码并在下面的代码中隔离了问题传感器:

import RPi.GPIO as GPIO
import time

TRIG1 = 13
ECHO1 = 15

##TRIG2 = 22
##ECHO2 = 18
##
##TRIG3 = 37
##ECHO3 = 40

GPIO.setmode(GPIO.BOARD)
GPIO.setwarnings(False)

GPIO.setup(TRIG1, GPIO.OUT)
GPIO.output(TRIG1, 0)

##GPIO.setup(TRIG2, GPIO.OUT)
##GPIO.output(TRIG2, 0)
##
##GPIO.setup(TRIG3, GPIO.OUT)
##GPIO.output(TRIG3, 0)

GPIO.setup(ECHO1, GPIO.IN)
##GPIO.setup(ECHO2, GPIO.IN)
##GPIO.setup(ECHO3, GPIO.IN)

while True:
        time.sleep(0.1)

        GPIO.output(TRIG1, 1)
        time.sleep(0.00001)
        GPIO.output(TRIG1, 0)
        print("anything")
        while GPIO.input(ECHO1) == 0:
                print("Works")
                time.sleep(1)
                start1 = time.time()

        while GPIO.input(ECHO1) ==1:
                stop1 = time.time()
        print("sensor 1:")
        print (stop1-start1) * 17000

##        time.sleep(0.1)
##
##        GPIO.output(TRIG2, 1)
##        time.sleep(0.00001)
##        GPIO.output(TRIG2, 0)
##
##        while GPIO.input(ECHO2) == 0:
##                start2 = time.time()
##
##        while GPIO.input(ECHO2) == 1:
##                stop2 = time.time()
##        print("sensor 2:")
##        print (stop2-start2) * 17000
##
##        time.sleep(0.1)
##
##        GPIO.output(TRIG3, 1)
##        time.sleep(0.00001)
##        GPIO.output(TRIG3, 0)
##
##        while GPIO.input(ECHO3) == 0:
##                start3 = time.time()
##
##        while GPIO.input(ECHO3) == 1:
##                stop3 = time.time()
##        print("sensor 3:")
##        print (stop3-start3) * 17000

GPIO.cleanup()

写着"print("anything")"的那一行允许代码编译,但是不带距离阅读,会继续打印"Works"表示它是运行连续在第一个 while 循环。没想到去掉"print("anything")"这一行,报错:

print (stop1-start1) * 17000
NameError: name 'start1' is not defined

打印到终端。上面注释掉的代码与功能传感器的代码相同,当与当前未注释的代码隔离时,可以正常工作。任何想法或建议将不胜感激。

谢谢。

我认为您遇到了时间问题,这会导致您的代码 运行 根据 "small" 时间变化而不同。

您的代码由于没有初始化 start1 而失败。

当你的代码延迟(打印"anything")是一个显着的延迟时,while 循环将运行 并初始化start1

当你没有延迟时,

GPIO.input(ECHO1)

不会等于零,while 循环不会 运行 并且您会得到错误。

我认为你应该初始化你的变量,你应该检查是否有你不知道的时间要求。

另请注意 raspberry pi 上的 运行ning python 将不是实时系统,因此请注意实时限制并小心编写代码对时间敏感。

我认为您遇到了申报问题。首先你需要声明然后声明全局。我更改了第 6、7、40 和 44 行。你看

import RPi.GPIO as GPIO
import time

TRIG1 = 13
ECHO1 = 15
start1=0.00
stop1=0.00
##TRIG2 = 22
##ECHO2 = 18
##
##TRIG3 = 37
##ECHO3 = 40

GPIO.setmode(GPIO.BOARD)
GPIO.setwarnings(False)

GPIO.setup(TRIG1, GPIO.OUT)
GPIO.output(TRIG1, 0)

##GPIO.setup(TRIG2, GPIO.OUT)
##GPIO.output(TRIG2, 0)
##
##GPIO.setup(TRIG3, GPIO.OUT)
##GPIO.output(TRIG3, 0)

GPIO.setup(ECHO1, GPIO.IN)
##GPIO.setup(ECHO2, GPIO.IN)
##GPIO.setup(ECHO3, GPIO.IN)

while True:
    time.sleep(0.1)

    GPIO.output(TRIG1, 1)
    time.sleep(0.00001)
    GPIO.output(TRIG1, 0)
    print("anything")
    while GPIO.input(ECHO1) == 0:
        print("Works")
        time.sleep(1)
        global start1
        start1 = time.time()

    while GPIO.input(ECHO1) == 1:
        global stop1
        stop1 = time.time()
    print("sensor 1:")
    print (stop1 - start1) * 17000

##        time.sleep(0.1)
##
##        GPIO.output(TRIG2, 1)
##        time.sleep(0.00001)
##        GPIO.output(TRIG2, 0)
##
##        while GPIO.input(ECHO2) == 0:
##                start2 = time.time()
##
##        while GPIO.input(ECHO2) == 1:
##                stop2 = time.time()
##        print("sensor 2:")
##        print (stop2-start2) * 17000
##
##        time.sleep(0.1)
##
##        GPIO.output(TRIG3, 1)
##        time.sleep(0.00001)
##        GPIO.output(TRIG3, 0)
##
##        while GPIO.input(ECHO3) == 0:
##                start3 = time.time()
##
##        while GPIO.input(ECHO3) == 1:
##                stop3 = time.time()
##        print("sensor 3:")
##        print (stop3-start3) * 17000

GPIO.cleanup()