我正在关注本教程:(http://www.seeedstudio.com/recipe/index.php?controller=recipe&action=show&recipe_id=166)
我将Raspberry Pi通过USB连接到Arduino
当我在终端中运行python时,命令将按预期运行,并且arduino会按指示闪烁。
但是,当我将命令放入python脚本并执行.py文件时,无论我传递的次数是多少,插针13上的LED都会非常快地闪烁3或4次,然后暂停并再次缓慢地闪烁。
我不明白为什么它没有按预期运行。arduino解释通过终端python(>>>)发送的串行消息和执行arduino.py的方式有明显的区别。
当我运行dmesg时,我得到:
pi@raspberrypi ~ $ dmesg | grep tty
[ 0.000000] Kernel command line: dma.dmachans=0x7f35 bcm2708_fb.fbwidth=656 bcm2708_fb.fbheight=416 bcm2709.boardrev=0xa01041 bcm2709.serial=0x4c5954ea smsc95xx.macaddr=B8:27:EB:59:54:EA bcm2708_fb.fbswap=1 bcm2709.disk_led_gpio=47 bcm2709.disk_led_active_low=0 sdhci-bcm2708.emmc_clock_freq=250000000 vc_mem.mem_base=0x3dc00000 vc_mem.mem_size=0x3f000000 dwc_otg.lpm_enable=0 console=tty1 root=/dev/mmcblk0p2 rootfstype=ext4 elevator=deadline rootwait
[ 0.002073] console [tty1] enabled
[ 0.195158] 3f201000.uart: ttyAMA0 at MMIO 0x3f201000 (irq = 83, base_baud = 0) is a PL011 rev2
[ 6.986035] usb 1-1.3: ch341-uart converter now attached to ttyUSB0
[ 271.283091] ch341-uart ttyUSB0: ch341-uart converter now disconnected from ttyUSB0
[ 273.926013] usb 1-1.5: ch341-uart converter now attached to ttyUSB0
[ 455.883149] ch341-uart ttyUSB0: ch341-uart converter now disconnected from ttyUSB0
[ 530.727358] usb 1-1.3: ch341-uart converter now attached to ttyUSB0
当我在终端中运行python --version时,我得到了2.7.3
当我在脚本中打印sys.version时,它显示[GCC 4.6.3]
arduino.py:
#!/usr/bin/env python
import serial
ser = serial.Serial('/dev/ttyUSB0', 9600)
ser.write("3")
解决了!
似乎打开串行连接导致我的Arduino重置...打开连接后,我放置了time.sleep(3)。
我的代码是:
import serial
import time
ser = serial.Serial('/dev/ttyUSB0', 9600)
time.sleep(3)
ser.write('2')
非常奇怪的是,此问题发生在可执行文件中,而不是在控制台中发生。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句