pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: 5 o0 [+ O) A U' t/ a
通用板控制见 pyb. - import pyb8 ?. Z$ r G% |) P+ T% I0 c
- 0 @$ k5 S- T. b9 ]4 p
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)5 j4 C+ G0 N" J" ?7 j3 {
- pyb.wfi() # pause CPU, waiting for interrupt' m6 @" c% M# s5 A
- pyb.freq() # get CPU and bus frequencies; }+ W& D- ~. r, |, x+ ?
- pyb.freq(60000000) # set CPU freq to 60MHz
; ^- U' ]6 k$ q$ q. z - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 * k# b* O( e% X2 E2 O
) E% S p% a+ \- x5 h3 H) z
延迟和计时使用 time模块: - import time. M4 K5 f; K8 _, n- w2 s
* S, X$ E/ _) ~3 t" t6 C- time.sleep(1) # sleep for 1 second
' D6 M' W% r v - time.sleep_ms(500) # sleep for 500 milliseconds9 @4 X( p. h7 _) o1 N8 m
- time.sleep_us(10) # sleep for 10 microseconds1 U5 o* e8 Y5 ]
- start = time.ticks_ms() # get value of millisecond counter+ N! H. [4 u3 v( w7 F" W0 _. ?
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
" m3 f& i9 w- H+ X' c; w( P
8 x2 x2 c0 B5 a) W内部 LED见 pyb.LED. - from pyb import LED; n: p7 ]7 k- q
: {5 i! {9 m2 D; Q+ ^3 b- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue7 O% X! |' j9 v! F, D6 e
- led.toggle()
0 K% i2 }* g$ q, x V y. U/ [* N - led.on()
7 B' r5 H- L9 S. A - led.off()
* P8 z$ S0 S* W+ e9 ^
* u; Z& I$ ?; n3 T$ @2 E) T- # LEDs 3 and 4 support PWM intensity (0-255)# M4 V' Q* b" a4 @$ P4 D
- LED(4).intensity() # get intensity% @5 Q* D( _. J# p/ Q! ^* C
- LED(4).intensity(128) # set intensity to half
复制代码
4 n/ ^- W' [3 i
6 l( U3 ?- A/ S1 Y内部开关请参阅 pyb.Switch. - from pyb import Switch* p) K9 j+ k2 ~5 R% t
7 ^% U8 S; f- R& [- A- sw = Switch()0 u+ \+ v4 M" O% k* Y; q
- sw.value() # returns True or False
; m2 g6 L4 s6 N! j3 Y - sw.callback(lambda: pyb.LED(1).toggle())
复制代码
6 f2 Z" U- `/ e+ x+ I& c
5 f4 j) }. q Q& r0 t- L( B. n: _引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
5 z- i6 I: \* [! R! i9 [* U - ; N! M- A- Z/ p% b4 ?$ Q3 L
- p_out = Pin('X1', Pin.OUT_PP)) v9 A3 i: n. b( @5 P8 g" T
- p_out.high()6 O# M; o* {+ R" D- W
- p_out.low()
- M! q% U2 g! Y2 a. o& }% @5 O( f
8 [; t" H" Q; h+ @- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
* o: i- T! \9 k1 f3 i6 t - p_in.value() # get value, 0 or 1
复制代码 + |+ o$ {* \" D3 E# w: t# r t3 V2 |
% e r3 f2 M8 u/ {5 s' @伺服控制请参阅pyb.Servo. - from pyb import Servo7 U/ G; Y) c/ P" ]/ |& @2 _& C
- ' G; I9 k |4 d4 q
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
. ^) C" r6 h7 P, X& `: k5 W - s1.angle(45) # move to 45 degrees
K: Q0 J( u) h$ _ - s1.angle(-60, 1500) # move to -60 degrees in 1500ms
2 G6 l: J& y& W - s1.speed(50) # for continuous rotation servos
复制代码 2 Q4 [- ^1 V9 V0 k# _% W+ O* W8 c
- F: c$ y8 r( W J外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
* _* v' Q: n: }9 _' W$ n! @
$ ]* L( |! `; ?2 Z8 @- callback = lambda e: print("intr")
. n9 _2 V4 U* [ - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
* f4 E, ~" U: }2 u! \) u" b. f
$ _/ ]) }& q. i; J8 ~$ G% n计时器请参阅pyb.Timer. - from pyb import Timer. ^) Y2 J h, t6 b4 X/ r
$ Z3 ~6 ` G1 H8 N- tim = Timer(1, freq=1000)$ ?; E! B2 f( \) `" b% I& O
- tim.counter() # get counter value
1 F/ \- o" S8 Y2 X I+ \$ \ - tim.freq(0.5) # 0.5 Hz6 Y. K# l6 K+ J+ D
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
9 T% j$ X+ t# Y) jRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
( l! E7 w8 r8 Q- G2 U% }7 h
Q3 n4 [3 T1 ^- b' I2 [" c3 f- rtc = RTC()& h+ K4 o+ H6 m. K6 O; q, @2 i
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time, m$ X4 Q" ^# ?! F/ {$ e0 j
- rtc.datetime() # get date and time
复制代码
L D* X2 V- |! P- XPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer( z* y6 @& {! s
1 D- P0 A. v* E. o- p = Pin('X1') # X1 has TIM2, CH1
& Z4 h1 I9 A: b, F. N# E* l - tim = Timer(2, freq=1000)2 C$ D- ]+ I9 {3 o2 O& P, @
- ch = tim.channel(1, Timer.PWM, pin=p)
* T4 t2 B6 b2 @; _' s+ h, j4 m - ch.pulse_width_percent(50)
复制代码
3 S! p! b1 g! H `2 ]) N+ e% B% }2 [ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC7 _( \& a5 [3 ] z w4 p/ `8 ~
- ) M, `* \, k u' r) |
- adc = ADC(Pin('X19'))# e5 O' x, o- N! }
- adc.read() # read value, 0-4095
复制代码 0 j1 c; r4 j! C: P
D6 { q# n) o- J' F
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC% {' s# C: C1 A0 Q; V" B
% H8 L! ?; }$ B. L& y! X- dac = DAC(Pin('X5'))
% f, {' {. L* e9 k! `1 t* z - dac.write(120) # output between 0 and 255
复制代码 9 H8 T5 G# L$ M, c+ H/ A
) V% ~+ J3 g6 q3 k/ `8 AUART(串行总线)请参阅 pyb.UART. - from pyb import UART
" `7 E6 Y4 c/ q5 H- S$ x% X* P; o1 s - 9 \" `, E$ Q9 a) y
- uart = UART(1, 9600)4 E! |/ g, l+ n
- uart.write('hello')! ~9 \2 L: n7 X! V5 s8 ^
- uart.read(5) # read up to 5 bytes
复制代码 % v2 s& \. R: |& d9 `; }+ H
1 M; r/ N0 j9 v8 G/ Z
SPI总线请参阅 pyb.SPI. - from pyb import SPI# o: v# V7 ^) D8 _
- ( e2 e. R+ }/ \
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
3 n2 n7 n( B: V0 g5 y( @ - spi.send('hello')
6 V9 \/ Y( _- t+ D - spi.recv(5) # receive 5 bytes on the bus
% h) w @6 T2 [6 m! a - spi.send_recv('hello') # send and receive 5 bytes
复制代码
0 d( W2 Z5 _7 ]' ]
0 ~8 \* B/ O/ qI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C. p$ r, {$ s) {
; h1 z4 g) K( W# f4 v- i2c = I2C('X', freq=400000) # create hardware I2c object. i/ U) e( z1 t! t7 c3 W9 Q
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
6 w5 Z: b2 ]3 a/ U - ; b: W1 T* _ C2 B
- i2c.scan() # returns list of slave addresses
6 Y c5 @6 v0 S' u# j8 Q - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
9 M5 [3 S- ?' I% g9 e - i2c.readfrom(0x42, 5) # read 5 bytes from slave1 S1 m' h9 n( F7 [" b
" f* ~8 m- _9 u- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
" x9 L1 j' a) r1 I9 @4 S1 p - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
, g+ u* M' {. m$ }1 ?" H7 k
% b' h* _0 n) V: h$ |* s注意:对于传统 I2C 支持,请参阅 pyb.I2C。
: H& K# a0 W# u8 p7 r- e8 KI2S总线参见 machine.I2S. - from machine import I2S, Pin
1 b# w: u. [0 V; f* Q3 v! c' h) w - 9 o7 I4 @: B# w# U1 M# N _
- 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 object1 D+ V/ v% U8 L: r" x: I
- i2s.write(buf) # write buffer of audio samples to I2S device
2 x/ l- v" u- H: |. x - ' _2 J; ~" \5 h- Q
- 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
a6 z1 [! g3 |/ G5 M$ r3 \( j' B# J$ A - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码 ; ^* |2 W2 A6 Y0 V" W
I2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 / S f# O. E9 j3 A1 C- Y* y
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
/ u; c( Z/ Z8 \7 L* m; L; |
$ o! q1 {0 g/ _3 D2 i/ q. k- can = CAN(1, CAN.LOOPBACK)) w6 J- l. Z+ a5 U! h, t
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
2 Z% K* J) V7 E- S/ ]7 W - can.send('message!', 123) # send a message with id 1232 @7 M& z0 ~; i+ m/ ^0 m* ]
- can.recv(0) # receive message on FIFO 0
复制代码 5 N6 ]9 r+ h7 J# v% s+ J
2 t. j/ ]" G0 W% t
内部加速度计参见pyb.Accel. - from pyb import Accel
3 o. ^+ N# t& q& q - 7 a7 F! C2 R% u+ k& [6 t1 A7 P
- accel = Accel()) U7 c8 m6 @3 c- x, o: [
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
- X, H# P9 \- h' @* T4 n5 G" d) n) G/ F( W/ {+ z4 S/ ~0 d. W
|