pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
* v- q) ~* b; l2 V+ T通用板控制见 pyb. - import pyb! i0 n% P& y$ J$ M" c4 ]0 J- J+ j
. I4 l# ?# [! w. x {- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
: r- y- Y& I2 h' p) M- j - pyb.wfi() # pause CPU, waiting for interrupt
' M' \1 ^3 y) O3 f/ P$ B8 \$ L - pyb.freq() # get CPU and bus frequencies5 }6 O6 E" r! ]1 Q0 t
- pyb.freq(60000000) # set CPU freq to 60MHz) W" q1 V8 F4 P! A/ R% a. ^' E' V$ K
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码
% l$ n! D1 z8 h' k, o+ p7 b6 p4 H; G" I7 e
延迟和计时使用 time模块: - import time! M% e! G. J3 T$ M5 }+ A' j
- 9 {2 b0 H* v: D- [
- time.sleep(1) # sleep for 1 second
5 E, k ^* p3 \9 K - time.sleep_ms(500) # sleep for 500 milliseconds
, Y( I- \6 i; N - time.sleep_us(10) # sleep for 10 microseconds
% j; ]$ c* a' A; t5 n - start = time.ticks_ms() # get value of millisecond counter
6 t3 \# z1 u6 O% t - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 + Z% s' [5 w, f L+ H
& o5 ^( y" H0 V8 g$ h! r$ f- G
内部 LED见 pyb.LED. - from pyb import LED5 q( n Y+ z+ q5 n0 a
- * Y% K$ \. u, e! s
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
2 x; v- b; t9 I' u2 i k6 H0 n - led.toggle()
! r3 n0 Y, \, g n8 V- [7 t - led.on()
" I5 O/ M# g! N& @8 R0 D( q - led.off()
/ z' f" ^0 j' k) [
; k( e- ?6 E" f2 @& F) f- # LEDs 3 and 4 support PWM intensity (0-255)
2 y/ R7 F9 W9 g9 Z1 k0 p - LED(4).intensity() # get intensity
+ x) x& a" H* j% x1 m - LED(4).intensity(128) # set intensity to half
复制代码
( b2 K. A% A( p" P
# N5 [! ]6 p7 L, b8 c2 T内部开关请参阅 pyb.Switch. - from pyb import Switch6 m$ e! }$ T! m& J
- / ~3 D9 |8 K% B6 x J m# G
- sw = Switch()7 `3 B0 S$ n( ^: G9 M0 b& F' L
- sw.value() # returns True or False
& d) G! g$ Y" `8 N3 s$ h - sw.callback(lambda: pyb.LED(1).toggle())
复制代码 9 K' p# x0 G, y, v1 \2 h
# w* z" T% |- K9 Q; _8 Q0 a引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin8 y2 N- Y# `/ P* u. Y
9 y3 F" b* d: k4 q1 i- p_out = Pin('X1', Pin.OUT_PP)1 h1 }. j4 a9 ?- ^: G, y
- p_out.high()
5 X$ K# l+ B. [; [, Q - p_out.low()
1 a% q* c/ u7 j - * Z: y& |0 E* f& l
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)0 L5 P9 y1 Y2 B7 {
- p_in.value() # get value, 0 or 1
复制代码
% Q1 r, C/ W9 W0 `8 @
2 M/ W3 k6 o) `* I, R' ?& I* R伺服控制请参阅pyb.Servo. - from pyb import Servo
) p4 v) d6 {5 g" D. K6 b u - * R2 t H' n8 y, q3 ?8 \
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
- G) F9 ^1 j; D1 D; |$ q - s1.angle(45) # move to 45 degrees
/ ?* X# h9 l8 ^9 k' C- K6 ] - s1.angle(-60, 1500) # move to -60 degrees in 1500ms
4 \" j( N9 Y4 ]2 M$ T+ |* S+ a - s1.speed(50) # for continuous rotation servos
复制代码
4 X; G0 l9 W* u9 b5 g& ]
. U" s8 J& ~4 @* p外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
7 ]2 a4 ~" x" q$ {9 }8 j - 0 r* r- M4 Q5 d9 p/ \
- callback = lambda e: print("intr")
! {4 o" b* r6 B( U. a - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
- B1 X3 o! z# P- H$ K0 `" Z6 x) X. F+ G' ^
计时器请参阅pyb.Timer. - from pyb import Timer( u2 e* F2 B& ]0 d+ B( [
# S, o% y! s9 N- o" V6 ]' _1 ~- tim = Timer(1, freq=1000)) S g' w L% L% k- m3 S+ D% u. t
- tim.counter() # get counter value* n% z, j, y6 o z: k9 h& F
- tim.freq(0.5) # 0.5 Hz
3 y( i& x( I4 E) i - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 4 O* Q A% h1 ~2 x4 b' D' {; |
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
$ v3 Q+ b- M3 w' ^
" Q! B! v1 N* w' v3 d- rtc = RTC()' l5 Q& y$ {2 B. @6 b3 M
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
7 ~; x1 k0 j2 b0 _ - rtc.datetime() # get date and time
复制代码 5 ^" P. @9 g6 z$ }
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
* j5 E# y+ a2 t+ y4 ~5 i/ i - 7 d7 p! e$ J/ D! Y
- p = Pin('X1') # X1 has TIM2, CH1# E% k4 Z5 X6 j7 K/ D- f5 R
- tim = Timer(2, freq=1000): @9 ]4 s5 e) k6 ~' N
- ch = tim.channel(1, Timer.PWM, pin=p)
9 m' @4 S5 G: D7 F4 X# L m9 @ - ch.pulse_width_percent(50)
复制代码
- R% x9 C, ]" d9 _ D& A* yADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
S I1 P' W& _
" }1 H& l2 h0 q! W$ F6 L- adc = ADC(Pin('X19'))$ N2 W& x; m3 |8 D, @" q) K
- adc.read() # read value, 0-4095
复制代码 9 ^( l% z G' Z
3 b9 m% M2 N' k$ w# jDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC* s/ V# m2 h/ Z& z
- + y( F" r: w, Q& b) N7 J2 I1 X
- dac = DAC(Pin('X5'))
9 N- a, F4 ?( T6 W" O( T3 M - dac.write(120) # output between 0 and 255
复制代码
( ^/ N' f- o# C- m3 I( z
# Y% ], R- Z# Z* ]5 W; l+ \UART(串行总线)请参阅 pyb.UART. - from pyb import UART* d z+ G$ `, m: e- F. `0 @
, J- _! y- ?4 B6 Q ^. k; p- uart = UART(1, 9600)& `+ ~6 y& b5 M- ?/ i
- uart.write('hello')
$ o( A* L0 V1 F. a) w - uart.read(5) # read up to 5 bytes
复制代码
( q' T, [( r: Q' ~9 v# g
2 u7 M- ^2 X) ]$ lSPI总线请参阅 pyb.SPI. - from pyb import SPI
: Y4 o2 ]& d7 M$ O - 5 p, ~4 ^4 B8 Y! r% x R
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
& v W4 E" h7 p0 e - spi.send('hello')# j, g) B6 I- Y6 o( n- d7 v# k- X
- spi.recv(5) # receive 5 bytes on the bus4 ~- Y/ I# V5 j8 e6 x8 k
- spi.send_recv('hello') # send and receive 5 bytes
复制代码
& V+ ~8 k/ F+ u1 n" B( t! |( u s- _# w, l- j- C
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
5 [3 A+ E) t$ @/ m! { - * q9 y+ c4 E1 M' v* i
- i2c = I2C('X', freq=400000) # create hardware I2c object8 y. a" ?$ S8 ?8 i
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
; K( v! c% f6 V' y - 6 @8 p& s8 ~+ K, C
- i2c.scan() # returns list of slave addresses- }) h7 [* a6 T: q' f& F
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
1 E' E' x- f- I* l8 @ - i2c.readfrom(0x42, 5) # read 5 bytes from slave
3 ~$ A( h0 J% B7 w' d+ V
3 ]( l7 ` u- r( D& O/ ]" c- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10. f+ k# ~# [& M+ S& M, u( k) r
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
0 R- A* V2 g% w' t6 L9 y; Z- b8 R; a6 [- F: x2 C" p9 k
注意:对于传统 I2C 支持,请参阅 pyb.I2C。 9 D' d8 w3 F0 f0 W1 t- Q
I2S总线参见 machine.I2S. - from machine import I2S, Pin
x! |, c5 L) s, z) E& K( T - ; V5 T: M) t! Z5 Z: o3 z1 H0 l
- 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
' b: j; u B% d k - i2s.write(buf) # write buffer of audio samples to I2S device
0 \6 `( h4 O9 | - 0 F- U& A c6 s" E. i
- 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
- ~: E) q# i1 }- d: N- D - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码 # d& `8 w3 \; f
I2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 : D& E" K) I @ G7 D$ R7 `, d" M
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
+ G; L# }% w2 J8 u0 X/ A0 T - 1 F; ?9 W' Z" a2 w4 u
- can = CAN(1, CAN.LOOPBACK)
c) K9 e- f8 l6 E0 \- c - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))8 ~- J+ e, T7 g
- can.send('message!', 123) # send a message with id 1232 d+ W+ h) B/ }
- can.recv(0) # receive message on FIFO 0
复制代码 3 t; \9 q6 q0 @# E8 P
, ]) [ S' T$ u6 U内部加速度计参见pyb.Accel. - from pyb import Accel
3 q+ M/ `2 V: E4 ?+ O - 4 x/ B/ {" Y) K. J5 ?4 c2 q' Y6 Z
- accel = Accel()" V% E6 D7 p7 {3 F
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 ) v" H9 f# x* |
) R" u: P$ [# n1 K8 C7 [
|