pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: 1 ?- O4 e! f, W- J. O! T# f$ o
通用板控制见 pyb. - import pyb7 c5 @" N) m1 }' G, h$ t8 Z
* S4 H* T' D; ?8 o% s! [, P) U- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
5 Z* I/ [/ Z ~9 | - pyb.wfi() # pause CPU, waiting for interrupt
; p* z/ O" F: h4 W) w - pyb.freq() # get CPU and bus frequencies L/ S3 M6 o* r$ X2 @
- pyb.freq(60000000) # set CPU freq to 60MHz
( R) n3 X& {+ l; ` - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 7 f! h/ }; U. T9 }% |6 G$ v* F' r
' l2 _) I$ a& o) H
延迟和计时使用 time模块: - import time
1 q! E) g z# }4 D, k, B* Y - 7 R* W( `9 y4 N. ^! H1 E" L) x7 E
- time.sleep(1) # sleep for 1 second J* R, N6 e2 j7 L6 z6 x3 ]" Z4 I
- time.sleep_ms(500) # sleep for 500 milliseconds
) I4 w8 A/ O3 {5 O& R - time.sleep_us(10) # sleep for 10 microseconds
( I3 ~2 e+ E/ |# L7 x z - start = time.ticks_ms() # get value of millisecond counter6 u: U1 D7 `6 ]3 a, v, p& C' ]
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
+ U8 E0 w$ s& [ Y9 o) [4 x5 I
& i) h/ E7 Y9 u内部 LED见 pyb.LED. - from pyb import LED( f0 j) `) w; E" F5 B* b Q3 e
- 0 x6 @" ?5 C# T6 u$ M$ i
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue- `' I. Y8 h2 G" Y- F# I
- led.toggle()" t+ \5 I- |6 R* _& |
- led.on()
o: `4 N* v/ l( H! Z t5 d - led.off()
: i' {$ k: Z' t- L: ^, N' s! d
+ o) S( G0 U O% _- # LEDs 3 and 4 support PWM intensity (0-255)
/ B8 N, ]( Q) h, y - LED(4).intensity() # get intensity
" t. O0 G; C7 g& R& D - LED(4).intensity(128) # set intensity to half
复制代码 3 A; m0 a( a# `+ a- x) T* s
) c2 k& w# f2 [ e6 D; `
内部开关请参阅 pyb.Switch. - from pyb import Switch
( v5 A A* r4 E
: H% |, x9 p2 O: ^) |' }& Y- sw = Switch() t7 g( v8 ^4 C5 [1 D
- sw.value() # returns True or False* p3 E! o4 z! u: P9 z
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码
* Y' h8 |: o. J' _. e
5 T/ d# a9 r% W, O) K( d- U引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
( s1 W# r( B9 N) y$ `+ C/ Y$ d$ e - 6 Y0 C! s: W( k! g6 F# `; K0 D
- p_out = Pin('X1', Pin.OUT_PP)
1 t4 n3 y2 d) L! X - p_out.high()
7 n M' C+ X8 D9 x - p_out.low()
3 P5 K" u J r/ y
; I+ N5 {0 a+ l {) H& j/ |9 S: B- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
: y4 G) P* X4 r' ~ - p_in.value() # get value, 0 or 1
复制代码
# R7 O/ c- x- ~/ W1 l- q8 e5 j1 k& A
伺服控制请参阅pyb.Servo. - from pyb import Servo
! k; v* t: b) t( r7 a/ z% S - 4 J, _1 ^1 i7 q
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)3 {; ^- `+ h; }5 i
- s1.angle(45) # move to 45 degrees
# A: o% w; r4 ]; W) u! \ - s1.angle(-60, 1500) # move to -60 degrees in 1500ms4 {) G: s' j& p7 Y1 v
- s1.speed(50) # for continuous rotation servos
复制代码
! a. @7 P1 @- T1 x$ _) N' V2 h/ x- d. F9 e
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
: j5 l3 W4 a9 ]9 m: X3 V: @" X - 2 L1 Z% M6 C/ {; |2 H; A1 Y$ V, ?
- callback = lambda e: print("intr")
; `8 P& ] w( H6 {0 @- A% y - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
- b3 ]+ M, f' A
! f/ r- X# p3 A: |" K计时器请参阅pyb.Timer. - from pyb import Timer
2 |6 [$ P3 d( }" X! d$ p
! J8 c! u) d) V, i7 Q- v0 j' N- tim = Timer(1, freq=1000)* G' @6 `& }: O, z/ l' o$ n7 \
- tim.counter() # get counter value4 e ]* G+ N8 X q8 _
- tim.freq(0.5) # 0.5 Hz3 N4 d3 G( w4 F3 @1 N; Z/ Q
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
) u$ e0 b! [3 HRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
3 o/ {: R' l( ~1 D W" _% D
# J1 U3 F; f& k( p* t- rtc = RTC()- b! M: h, a8 {$ p( Q% a
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time6 s) [: @1 y6 I# e6 t* J
- rtc.datetime() # get date and time
复制代码 1 V+ i1 p. }. r( f
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
0 _$ ~7 a; w1 z/ R) N& F8 D* l - 9 W0 n, j! q0 ?/ W
- p = Pin('X1') # X1 has TIM2, CH1
- u8 ~3 A5 t& P9 }' x - tim = Timer(2, freq=1000)
; o; I. @4 X7 U' ?: N/ b# M - ch = tim.channel(1, Timer.PWM, pin=p)- B0 p# }& |; g9 \3 X0 |! c+ B7 i
- ch.pulse_width_percent(50)
复制代码
. ]2 D$ o5 x( ]0 jADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC' b% J) b% ^1 d& e
- Y3 D7 q+ ?7 d- N2 p& [! y |
- adc = ADC(Pin('X19'))
* f }; m8 E* j6 ^ - adc.read() # read value, 0-4095
复制代码
H7 I' X# J1 y4 \& M& N9 L8 i* n8 v- d- o+ N+ Q( c
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC% p% n. E0 K6 x- f: S U, l
) z6 {+ w* Z3 Z3 [) x5 l- dac = DAC(Pin('X5'))8 G. m( k! Q; h, T6 H0 F
- dac.write(120) # output between 0 and 255
复制代码 - p' T' L& w6 Q
4 X1 B! W: {/ L6 L- [
UART(串行总线)请参阅 pyb.UART. - from pyb import UART
0 l6 J' y$ c* P. O5 ?& r" W. A
% m* U* C& x$ P& |; l# g8 k- uart = UART(1, 9600)
. s% m& D( _/ E - uart.write('hello'): k4 K) o. k% \- h s; ?
- uart.read(5) # read up to 5 bytes
复制代码
; R( H$ h" K; D( @% P P5 H! M9 ^# q, A( V/ ^6 n
SPI总线请参阅 pyb.SPI. - from pyb import SPI
- Z R F8 {, M0 H# ?6 i - - {3 Y0 _4 X4 {8 }! y* E- ^
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
: x) a% c% F, R. z8 I- K( I; Z0 _ - spi.send('hello')% t) [7 ?! H3 y9 d. _5 m7 R
- spi.recv(5) # receive 5 bytes on the bus! L& L! w& [" c
- spi.send_recv('hello') # send and receive 5 bytes
复制代码 7 m$ D4 c' Y2 V/ k1 n1 {
9 _' Z) s% w3 VI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C4 E3 `/ x; R& p
- / P3 y# {* O, P
- i2c = I2C('X', freq=400000) # create hardware I2c object, B# T2 U Z' ]5 Y L/ \
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object. }; P+ `. f- n' D5 Z; l8 E$ `$ _
- i: ~" m: @: i' }% i' X$ u- i2c.scan() # returns list of slave addresses6 M! a) M, c: _( P0 Y
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
! m" P6 _; N y) J - i2c.readfrom(0x42, 5) # read 5 bytes from slave
3 j8 t4 q: o" z7 r - 8 P. _1 o0 n9 C' g; j
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
( F; j8 }; r7 \$ i& V D - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码 ; A% t+ \/ P! L
# j* f( X( ^( j
注意:对于传统 I2C 支持,请参阅 pyb.I2C。 . ^% E* A" p/ Q. E
I2S总线参见 machine.I2S. - from machine import I2S, Pin# X& Q- T c+ t# |2 s+ {$ J3 z, q
- 0 o4 b% P. e) G. t0 c1 D
- 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
$ y# @" K2 M$ D# F; A - i2s.write(buf) # write buffer of audio samples to I2S device1 v# h3 \3 r. `( B8 ^( g3 t! t
# L2 I0 D' J. Z3 o6 F4 q- 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 object" d$ q8 Y; l3 P; _4 M
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
, g6 K% J6 e( |2 p* V: sI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 % @( M" Y& j6 l# d! [% G, c7 W: R
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
- l, g Q% }( E; f3 {) I - 5 ~- i: j" Z8 l" o( p% Q# I
- can = CAN(1, CAN.LOOPBACK)' m( g# z0 V' H* P1 ~" z ]
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
4 f0 [2 a) o% ?) J; v4 t - can.send('message!', 123) # send a message with id 123) I9 v' B: p! e: y
- can.recv(0) # receive message on FIFO 0
复制代码 7 F& W2 B4 {6 G0 Z
: \2 L9 |/ d# s% W
内部加速度计参见pyb.Accel. - from pyb import Accel
0 v4 d5 r; V9 o - , D$ G* S9 N6 ]. ^3 O1 V% e o) a
- accel = Accel()# X8 L' P. t- Z- r. u0 W. C1 z9 s
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 2 J5 S4 b; x S9 N. w
: Q' R8 Z4 E( \# `8 W* v. B |