pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: 4 f, G0 b( L4 f9 y
通用板控制见 pyb. - import pyb
- |3 I& u4 c, j' k4 ? - : Q8 A6 {+ U. Y8 [7 e8 \ S: F. |
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)3 b3 g4 Z1 n$ J' c" G$ @
- pyb.wfi() # pause CPU, waiting for interrupt* g' H6 y- ]" u
- pyb.freq() # get CPU and bus frequencies; R" H# d2 K, K' L
- pyb.freq(60000000) # set CPU freq to 60MHz
; u5 Z0 X9 S+ A6 W7 G) p - pyb.stop() # stop CPU, waiting for external interrupt
复制代码
' m) J5 f9 n4 m4 {: n6 x: ]0 Q- `+ j, m' e# M1 V4 s$ P: J
延迟和计时使用 time模块: - import time
2 u- y6 j4 Y) O
* r, ]# Z! ~3 c. ^) m6 L- time.sleep(1) # sleep for 1 second `4 b, \& L( i
- time.sleep_ms(500) # sleep for 500 milliseconds- R s2 O+ q* z$ H: m
- time.sleep_us(10) # sleep for 10 microseconds
0 H8 n; O, F' y0 X5 m( w - start = time.ticks_ms() # get value of millisecond counter4 m- h% ^! _( \
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
, F& Q" V# w- K
2 ? X% M+ j$ g2 O内部 LED见 pyb.LED. - from pyb import LED- |/ i9 z# h' `) j; f% B1 R, T! y( {
- 5 x, l8 |0 w4 o$ T; c
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
2 @/ f7 y; j- A# ?: H+ J% C - led.toggle()- N) J7 `3 `$ q' K2 W5 ^4 g% r
- led.on()
8 e. c# i0 i& \2 I - led.off()- [: c( k5 i6 b) S4 `/ y7 {
- 2 W G. A4 D( B g$ Q0 O* ?
- # LEDs 3 and 4 support PWM intensity (0-255)
6 C) ^3 L8 \) i1 \1 ? - LED(4).intensity() # get intensity/ s, J6 B o+ W0 x
- LED(4).intensity(128) # set intensity to half
复制代码 6 j% c( ]" L1 r
4 _; D3 K1 N: U) K% b' A+ }内部开关请参阅 pyb.Switch. - from pyb import Switch. Y% \; X( s" r/ E7 I
- : M9 F* T4 N$ l# ?
- sw = Switch()
* ]/ |; \: L+ f0 }' B' I - sw.value() # returns True or False
# I) ?& E+ T5 g! E5 E9 a& k8 } - sw.callback(lambda: pyb.LED(1).toggle())
复制代码 $ P1 o k# X W& S1 U
' a/ s& @; D: G2 V' a; p/ c引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin2 Y* j; X/ G- \& ^+ e' Q3 v
/ g- H8 ?: b5 u/ R/ `. a- M% _- p_out = Pin('X1', Pin.OUT_PP)
/ l5 s" p) P$ R8 M; m - p_out.high()" U$ }& x/ `- l/ |, F& I
- p_out.low() K+ z. B0 W6 s( ~( ~4 f- I0 V
- 9 C* K* X) A6 k- L _
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
: P( z* a# \4 b7 _8 @3 ? - p_in.value() # get value, 0 or 1
复制代码
% l% v3 b# b3 \5 U8 y4 X
- y( ~/ F2 |& F9 H+ Q( o B1 @! p7 n$ Z伺服控制请参阅pyb.Servo. - from pyb import Servo# C; L" [6 V, Y- w! K2 w
$ b$ ?9 c- b8 e/ T5 Q' x- s1 = Servo(1) # servo on position 1 (X1, VIN, GND), [- d+ j. u1 `- B3 K
- s1.angle(45) # move to 45 degrees
- z, F# ]; t" {. l - s1.angle(-60, 1500) # move to -60 degrees in 1500ms
! c9 U" }9 e# y - s1.speed(50) # for continuous rotation servos
复制代码
2 `( C: X. @. W. p4 z. ?& H; D' }, d; O4 T
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt# C$ f* B9 B% z' f+ Q
7 g* w/ @6 m2 C4 `" s" G: i- callback = lambda e: print("intr")
z" u! b- c/ [4 A$ q - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
7 ]; k) `1 A& ]+ x; _4 |* Q! i
% u* V3 @* X" v+ m计时器请参阅pyb.Timer. - from pyb import Timer: b' ^' u2 x7 \: \; w9 m: [2 `
* A( c3 r& P% x! V( L* V- tim = Timer(1, freq=1000)% J) T' `. @+ c9 v6 e( u E
- tim.counter() # get counter value
8 S V1 L9 D5 [: A3 S - tim.freq(0.5) # 0.5 Hz% t+ O, J; c" I! ?, T
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
4 Y9 V. J" O+ K1 c% zRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC/ O) C( _, l5 L; [7 t
- : P0 J* W8 B% Y3 z( x
- rtc = RTC() S5 |- }% n! v( t& f# _7 J
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
' x0 ^# R2 l0 `( ^7 Z) n - rtc.datetime() # get date and time
复制代码 $ e1 @$ C" `6 |" }/ l
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer3 M% q Q; C7 G5 _8 O7 @0 j
- 8 y- B' T& v! T
- p = Pin('X1') # X1 has TIM2, CH1! }' S: @% P' c
- tim = Timer(2, freq=1000): E0 F! O2 S* z+ {% k
- ch = tim.channel(1, Timer.PWM, pin=p)
% v. O/ x" B, `! ]% m# c7 F# z. } - ch.pulse_width_percent(50)
复制代码
# t8 @& a9 g/ P3 b# t2 ^1 S$ T: JADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC3 q; b9 ~: v2 V; H( d7 O
- ! A- z4 n& N' W5 a$ }$ k
- adc = ADC(Pin('X19'))" k" B& V% F) f. w6 B
- adc.read() # read value, 0-4095
复制代码
" o# D3 Z, c( v# d0 \
* |5 F; a/ v8 o% d6 S* |0 bDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
7 \5 d+ @: F' T: V' H/ R% I
/ V1 ]( v- Q4 s& E' R- dac = DAC(Pin('X5'))) r9 |, W& y9 X8 d! G7 ?+ {
- dac.write(120) # output between 0 and 255
复制代码
# U: h5 G! k, D7 S- h# U5 s7 d1 R2 @" G8 u1 E1 ]/ z' O, W
UART(串行总线)请参阅 pyb.UART. - from pyb import UART
/ q9 l0 N- _. G
2 ?: u/ M" L6 {, R- uart = UART(1, 9600); Y9 |2 s% M* O( z$ n7 }% U% @& f
- uart.write('hello')9 f* }8 R8 y/ m' A' d
- uart.read(5) # read up to 5 bytes
复制代码
3 I& k x5 m: T1 x, N
5 Z- B4 l6 e7 S. iSPI总线请参阅 pyb.SPI. - from pyb import SPI
# m' w+ F# c+ y, b - 1 m+ i8 p0 e7 @ ~. O+ t, h
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)0 w8 f7 D9 P8 s0 L$ w
- spi.send('hello')
7 P% P7 O6 M! z9 `# R2 p( _ - spi.recv(5) # receive 5 bytes on the bus; W( a7 z B3 N! m/ d& w' _1 [
- spi.send_recv('hello') # send and receive 5 bytes
复制代码
" ^: I4 x1 R6 d
1 J4 @% g5 p5 f' Q* O# MI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C3 R! L+ g4 s* w
1 z3 ^( d2 c. o& z- i2c = I2C('X', freq=400000) # create hardware I2c object
: l1 |$ N) o3 s* n. D - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object% L; C: \7 s Y
- 5 f$ u( P$ |. E0 n) o
- i2c.scan() # returns list of slave addresses3 p# o- k4 y) y9 u
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x428 z1 M8 P( h4 p+ z0 z6 g
- i2c.readfrom(0x42, 5) # read 5 bytes from slave
+ n1 ]" m1 q. o - 3 ^4 c9 d6 _) ]' S
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10& _; {. M* X) `8 U2 h+ K
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
+ t% x$ f6 D8 f4 R% H/ l# H
, r. c9 W4 e6 F4 l& c3 f注意:对于传统 I2C 支持,请参阅 pyb.I2C。
. z9 i% Z+ L. y. `0 SI2S总线参见 machine.I2S. - from machine import I2S, Pin& @# o* D7 G. {% S: [+ P% l0 c u! {
- * D3 @. s5 d% l: H8 T
- i2s = I2S(2, sck=Pin('Y6'), ws=Pin('Y5'), sd=Pin('Y8'), mode=I2S.TX, bits=16, format=I2S.STEREO, rate=44100, ibuf=40000) # create I2S object
8 h+ _3 R6 T) U9 W* y6 { - i2s.write(buf) # write buffer of audio samples to I2S device9 H3 V7 a* B) @4 q, J6 A
$ ^- u2 X( d+ }; M- i2s = I2S(1, sck=Pin('X5'), ws=Pin('X6'), sd=Pin('Y4'), mode=I2S.RX, bits=16, format=I2S.MONO, rate=22050, ibuf=40000) # create I2S object
% d3 E# }' W# V6 W, C* l# @: Z C/ N - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
+ @/ M/ N- {- @: t( P- xI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 % @7 {8 D9 f' L% n% t" U
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
2 d3 \) X( n# U4 S4 o7 G0 d
! t3 d1 f* h4 }/ H" y, J4 N- can = CAN(1, CAN.LOOPBACK)
; F, L' ^ U: _% U5 ]4 R( [, o - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126)), O9 H/ g$ F* \0 X! y' d0 p
- can.send('message!', 123) # send a message with id 123- R/ ^( x% v% x2 e
- can.recv(0) # receive message on FIFO 0
复制代码 * A6 h* X4 F4 ]' Q) M% |
4 x! ~3 u6 O' U! s5 Q内部加速度计参见pyb.Accel. - from pyb import Accel
, |6 T. P- y; a, J. z7 {
! \9 U/ }9 H; P, A/ m6 D- accel = Accel()
, W( v- J6 X2 W3 R* | - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
9 U' T& r* x6 G% f
# P: j, ?" |# m( m) V+ { |