pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
& X$ ~; M( b$ I0 y8 F0 }通用板控制见 pyb. - import pyb
/ J8 D; C* o, Y" z& m: ]$ n
/ f7 o+ C* \. H1 V4 ]- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
; ?7 z# }6 ?( [ - pyb.wfi() # pause CPU, waiting for interrupt% {/ `6 w$ [" L! |; [, a8 j
- pyb.freq() # get CPU and bus frequencies. E1 D; \ u* a9 G/ ^
- pyb.freq(60000000) # set CPU freq to 60MHz, E& [. G8 z* }3 d+ v5 g7 X G* B
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码 + ?7 C- a2 X+ p" C* ?; [1 R# w
% T. _. f% `6 i4 x; K; [8 B4 c
延迟和计时使用 time模块: - import time5 i. o3 }0 p# @7 D# j
" b/ V5 j+ B* X9 f5 t* Q$ D- time.sleep(1) # sleep for 1 second
# k: q% r0 y0 u( `2 _- {& E - time.sleep_ms(500) # sleep for 500 milliseconds
* b3 b; N( ]" e$ e, A% Y - time.sleep_us(10) # sleep for 10 microseconds+ \. d9 g. g" ? Q9 ]
- start = time.ticks_ms() # get value of millisecond counter: n; Y" u ~/ `( S2 L
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 3 ]! |7 D1 A; Y$ A
; f1 J7 m7 y0 E- P0 Y8 i6 I# V7 q5 s内部 LED见 pyb.LED. - from pyb import LED
& V- U' b* b# O) J4 q - 3 u* U2 y9 i, d2 I6 {
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
) X& t9 j- G3 I - led.toggle()
- R* `5 A A+ t+ ~. j- y - led.on()
' `+ C7 C( Q d' r# _+ F4 g" _6 D - led.off()
3 n: w: ^! r5 g. q( ]2 d0 S9 v - ; D& s1 S; N- {/ b$ j) Z. _% b
- # LEDs 3 and 4 support PWM intensity (0-255)% D4 i% ?: \0 @7 Z4 Y1 }
- LED(4).intensity() # get intensity3 Q+ w! p L7 Y* M
- LED(4).intensity(128) # set intensity to half
复制代码
5 p9 `" Y" x' _( t
, c# e5 E- Y5 S: c4 f内部开关请参阅 pyb.Switch. - from pyb import Switch
1 ?: s2 C; w6 r5 c
7 }( a0 w; E: ?; j3 c) a% L6 N- sw = Switch()) q8 c! E- ~( l! b; Z0 R! C. J. v. n
- sw.value() # returns True or False
t: f+ G" F" R - sw.callback(lambda: pyb.LED(1).toggle())
复制代码 - q W$ H; n+ \
9 _/ d& u7 P9 K3 E9 _引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
0 f% w5 ~; C& X7 \5 Q4 _) H
, W+ Y% {9 z( y$ ]3 \! X( R- p_out = Pin('X1', Pin.OUT_PP)6 S4 { w, n- C( l0 V8 _) p- e
- p_out.high()6 j: J8 P z5 a
- p_out.low() J* X+ i+ u+ y" X/ k" a( B
+ I6 \- X, `4 P- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
8 b& D# P: W f W3 Z- p |; `$ m! @ - p_in.value() # get value, 0 or 1
复制代码
& `% a9 Y Q q" C. M/ `: Q6 ]9 U6 t( @% h) p; V8 @
伺服控制请参阅pyb.Servo. - from pyb import Servo
h; }. R, D3 t1 H
7 K' L( g4 h J+ E E: Z3 c- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
0 k" s9 x& t0 U1 g1 Y% U5 J - s1.angle(45) # move to 45 degrees
~9 K8 _2 v k' ?) J6 ` - s1.angle(-60, 1500) # move to -60 degrees in 1500ms' b {9 t5 z0 i2 v5 f9 B
- s1.speed(50) # for continuous rotation servos
复制代码
* b8 q8 [( U" |0 y! Z, O% X# e# q. i% D7 B4 H* @
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
3 @# }+ }5 v' e
% H( j" v8 R# X; V3 H. P, W- callback = lambda e: print("intr"); g n6 {* i) h3 e
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
8 }' T$ S r- A
4 P: B7 Q+ h4 q# Z; a计时器请参阅pyb.Timer. - from pyb import Timer
+ T. ]3 n5 S0 t1 I5 ?0 N - ! r$ i1 r; g. m$ i
- tim = Timer(1, freq=1000)
. C0 u8 P# {% @0 \( @ - tim.counter() # get counter value: i* g) K6 m2 a! ~9 X* q8 M
- tim.freq(0.5) # 0.5 Hz( N1 A1 b2 @* h% R
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
$ v. d/ h0 Z1 y5 g( S3 HRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC1 a8 Z0 W5 j4 D7 ^# H
7 m- T( L8 D6 b5 R- rtc = RTC()( M: U. B y( o7 V8 j }- H
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time0 M2 U+ @) U; C* k# K
- rtc.datetime() # get date and time
复制代码
/ Y, n1 E7 G$ h0 m% M! e- EPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
4 O' X9 e$ l* @0 v5 S+ |
6 Y* m9 h+ w2 m- p = Pin('X1') # X1 has TIM2, CH1
, X5 A/ v( ]! \. ~ - tim = Timer(2, freq=1000)2 K; I( f, c Z: l6 J4 i# w; F
- ch = tim.channel(1, Timer.PWM, pin=p)/ \: |0 |) a1 _1 H( c
- ch.pulse_width_percent(50)
复制代码 8 T$ o9 X( |3 B, G2 A
ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
/ Z9 |7 T1 [' f4 I% { - + n& b7 U% h4 ^! f
- adc = ADC(Pin('X19'))( D9 G3 Q* w" o9 W" |% d, L7 X
- adc.read() # read value, 0-4095
复制代码 - r' P' |. s; c; {) f7 q8 q, F$ v
9 m" j( w2 }8 v7 g, @, _, YDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
) E! i1 A, Q b* P! \ U( z8 z - 3 h9 B/ S7 g# d# j* l! L
- dac = DAC(Pin('X5'))
" l8 `+ z3 g, { - dac.write(120) # output between 0 and 255
复制代码
/ Q: P6 o! F2 d2 M2 h9 j4 [; ^, m) T; {! |; U0 \
UART(串行总线)请参阅 pyb.UART. - from pyb import UART
( c, F/ y8 P8 f! J3 i3 i" H6 ]3 ^) E6 H
2 ~7 B3 Y: q2 {5 F$ ` W- uart = UART(1, 9600)
) H+ A; U% y5 ~! ^5 { - uart.write('hello')% v5 t0 K9 n. l7 j4 R" k- L
- uart.read(5) # read up to 5 bytes
复制代码
& v" u7 t' x$ E- |0 I" l1 h3 ~6 t$ D5 d& y9 I0 G
SPI总线请参阅 pyb.SPI. - from pyb import SPI
9 n$ B1 X* m, x- v1 Z - 3 z) w: i6 z# A7 H7 o
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0): D0 I6 Z8 V" z" p. D/ c/ O/ x
- spi.send('hello')* b, P+ x) F% E" p2 r2 u
- spi.recv(5) # receive 5 bytes on the bus
- z! s/ e1 ?1 c! r- u7 N1 y5 y3 k4 J - spi.send_recv('hello') # send and receive 5 bytes
复制代码
, f) `! C2 m4 X7 o5 s) U4 B5 k0 Q5 x0 `6 r2 u9 l/ V0 \
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
; s! l! G l7 i' X. g! _
7 h6 M8 f6 }7 k" I) h5 Z# w- i2c = I2C('X', freq=400000) # create hardware I2c object
0 M" F8 ]5 |8 k; F - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
$ W2 U$ k7 z H; W! O3 H - 3 C J+ x3 X; F' _/ Y
- i2c.scan() # returns list of slave addresses
$ l. x3 {) j& N% S' A8 B8 S7 W) w% L - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42 P0 Z6 r: o/ v$ X/ h) m
- i2c.readfrom(0x42, 5) # read 5 bytes from slave
# Z4 @, t% u$ {
7 ?4 X' \$ }5 A; ~' C* j; q- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10( l% Z4 X* [5 g' n
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码 ; w9 G5 x; n$ p0 S! h% L
Q5 ~5 ?8 s$ V2 t4 W
注意:对于传统 I2C 支持,请参阅 pyb.I2C。 ( S1 X6 M+ M( i0 q7 T
I2S总线参见 machine.I2S. - from machine import I2S, Pin
1 K4 ~, X$ [. T, O, N M m+ ?' T - , L w" ?! D8 W' A( e$ i
- 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: M* |- w: q; k+ e
- i2s.write(buf) # write buffer of audio samples to I2S device
4 Z7 \0 z6 P$ h& v5 k" M! L8 S' |
0 J+ {% N: \8 n7 I( P9 Y- 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 object7 U7 y9 w5 ^2 n }( u A/ R/ O
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
5 q0 Y$ t* s- ZI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 : @, _% P6 s& b1 _% u3 |/ f% O
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN5 a' f" |- x6 r5 l9 W, B/ C
- $ P- Y6 R2 U5 |+ c9 o: f
- can = CAN(1, CAN.LOOPBACK)
4 i7 O: j4 h2 h7 {6 {" { - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))+ y( ]8 N: O- V* |- B* E: T
- can.send('message!', 123) # send a message with id 123 U/ S% {* I% B$ T( u. \
- can.recv(0) # receive message on FIFO 0
复制代码 # v- z4 m5 W3 h* v9 J0 O( l3 K
( C& C5 U4 n" k6 z& e- M9 W: S' S
内部加速度计参见pyb.Accel. - from pyb import Accel* Z) q. q4 l$ ^
. M5 ?: n7 |$ R- z; @' ]- accel = Accel(); C& U/ G/ _* D4 |& m3 B
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 * ]0 B# C* Y; `/ b/ ?' T3 x
% O7 l6 M9 D6 M, k |