pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: 8 ^" M' [, ]2 M- B: A2 n
通用板控制见 pyb. - import pyb
' y5 {( f7 e; D8 ?$ H M6 Y- e - ' X1 ?9 F8 }7 t. c( P- x
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)( Y I2 t, l; {& b! o# ~
- pyb.wfi() # pause CPU, waiting for interrupt
( I! |4 a0 L* y6 R - pyb.freq() # get CPU and bus frequencies5 y1 i" j0 x# F0 W4 H. U
- pyb.freq(60000000) # set CPU freq to 60MHz
/ O7 Q( d6 i! M f - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 6 z( D7 h4 H. q1 g- t( ~$ }; N- y
! w: D2 T, o- G- m延迟和计时使用 time模块: - import time$ [, v; \& v h! x7 y$ u
- 6 `- Z2 v. `) W* a4 d) Z
- time.sleep(1) # sleep for 1 second+ v6 R6 `" O) J6 i1 y
- time.sleep_ms(500) # sleep for 500 milliseconds
' C l S8 t2 u - time.sleep_us(10) # sleep for 10 microseconds8 c8 h3 e$ k- {- H! }, W6 P
- start = time.ticks_ms() # get value of millisecond counter/ Y0 B( K; A$ n# ~, U
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 8 G, F/ p E6 Y+ `: x
# Q2 S0 J' l4 [+ }: F8 B1 f
内部 LED见 pyb.LED. - from pyb import LED; J3 o$ K; ~# B5 @9 q
- % _+ _: A5 p5 {. @& p
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
$ k4 l- z0 n. x. y1 a - led.toggle(). R$ } b: D2 y# E8 f; M
- led.on()
& ?- ^) Z0 I% J - led.off()- p u! U, ]) j% ~
- ' R+ I5 |6 v. y3 v
- # LEDs 3 and 4 support PWM intensity (0-255)) x% S- `( W! D, I% j6 T6 u
- LED(4).intensity() # get intensity
) f7 B2 J q9 W - LED(4).intensity(128) # set intensity to half
复制代码 1 h8 b( i% U6 }4 p ]$ d# j
4 o: b; [1 K# v$ B6 ^内部开关请参阅 pyb.Switch. - from pyb import Switch
. T; ]( }" S) G; F
6 i" ?* }1 j7 ^4 f i% N9 U ?- sw = Switch()
# `4 r* o' B/ C1 m0 q' K5 f - sw.value() # returns True or False
3 a i! U' S; E* L( T& r - sw.callback(lambda: pyb.LED(1).toggle())
复制代码 7 ^7 L( a" c6 o3 p6 }1 P% L* @6 g) G
( V/ ^8 n' v/ [/ e
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin: M. w, N, N% I! P' k
) h, b/ ~8 B: V0 O" [# z, p# d. r- p_out = Pin('X1', Pin.OUT_PP)/ F; |. `! h% R+ Z
- p_out.high()# z, L: c) j O1 G9 B* c" V9 }( g
- p_out.low()/ q: _; F* f* |; R
" j7 H' u4 m( L# k- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
% E, n$ q8 O7 v. D) i ^ - p_in.value() # get value, 0 or 1
复制代码 ) n: v4 Z. x0 H' e& J7 _7 y3 |
' P5 {- Q7 I3 ?0 I6 u. d伺服控制请参阅pyb.Servo. - from pyb import Servo4 |! v% B: ^: m( B
- ! \% l' Z; d9 m/ d
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
2 T! ~2 ^1 f& ]3 c( B$ B5 X+ `" w - s1.angle(45) # move to 45 degrees3 [: l" ?/ T6 s' i/ A$ G- T B+ Y
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms
: W$ W' o! s9 A) d9 ^. f - s1.speed(50) # for continuous rotation servos
复制代码
4 F- A; g7 A/ g" J8 T& o
8 ^; a/ r, z: @4 R% p外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt! U( v' e# s9 E4 j: F% v$ g# G
- # ~! Y7 K3 p3 D
- callback = lambda e: print("intr")+ Q/ W$ z: b. q e' ^9 m+ W7 {
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
& k; r' Y, a6 s/ T) q" l& h. d, }, n8 @8 T6 B8 i" y/ s2 P
计时器请参阅pyb.Timer. - from pyb import Timer
- g/ u2 e k0 L
- g0 Q+ Q. q( D6 }* H- tim = Timer(1, freq=1000)5 I8 ]0 w8 H! b1 M/ P" M
- tim.counter() # get counter value: w; `3 H" ~" |& ]
- tim.freq(0.5) # 0.5 Hz: U2 \# }0 a, f P" l$ y$ V
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
! f* L9 S9 v5 J+ @RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
' _/ q( [5 r; v# v$ F4 L4 {# _
5 P/ i: M. Q1 t5 H- rtc = RTC(), |" |' M$ L5 ~, M
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
- j8 c5 Y8 J a$ c/ m. E* g - rtc.datetime() # get date and time
复制代码
0 `; k3 e4 {' aPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
) z* \: T# e. q/ v) ?+ j
* ^5 ^# w5 T1 `- r2 b3 x* N" G- p = Pin('X1') # X1 has TIM2, CH1, m9 v$ R& @9 F6 ^3 e
- tim = Timer(2, freq=1000)
! d' ?! g6 x$ C6 }8 S4 I - ch = tim.channel(1, Timer.PWM, pin=p)
7 e. ?, O/ _3 c4 a - ch.pulse_width_percent(50)
复制代码
2 H$ H; n. ~3 X# jADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
: S- F$ m8 `+ i! {- b
6 n8 X5 G' B3 v+ Y8 n2 K- adc = ADC(Pin('X19'))2 J- g$ F8 ~ n* y" p1 H
- adc.read() # read value, 0-4095
复制代码 / u0 {+ M* m% H% V( o
! D) k% q( ^7 U; ]. \DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC+ x, ]' n% _+ t- s0 _3 e8 @- C" K
- d% L! V! C8 K, F
- dac = DAC(Pin('X5'))7 Z4 K0 v9 k4 G
- dac.write(120) # output between 0 and 255
复制代码
0 k2 f* }: K/ _* C% s% q( u# c8 `% c6 i: W0 k9 t
UART(串行总线)请参阅 pyb.UART. - from pyb import UART& `! H8 p! G. C5 h; \0 I& W
# P y$ q C$ s. [2 }! m- uart = UART(1, 9600)
' _3 H4 P# z) b: c2 \$ c& ~ - uart.write('hello')" K3 ~' p& m, B4 m2 U2 i; {/ Q1 V }
- uart.read(5) # read up to 5 bytes
复制代码
% B: ^; U8 p% X7 M3 ]1 i) `
' b6 D# g- |# f) W9 B1 }SPI总线请参阅 pyb.SPI. - from pyb import SPI: h9 i; g5 `) \2 j1 w
% w( w3 U5 e! l+ w# y, F- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
9 [2 h0 z! d/ d$ _/ V - spi.send('hello')
' B1 o/ M2 h' W. w7 Z - spi.recv(5) # receive 5 bytes on the bus+ A) v$ j$ v$ S4 ~$ e# w
- spi.send_recv('hello') # send and receive 5 bytes
复制代码 $ c6 k @) N- R. I* D J0 w. j
" d+ R( S7 J- S8 O8 I- \! @9 ]I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C# b" u& J; m" S
- ' w& p8 [: k3 j6 g4 D" K" H s1 A" [
- i2c = I2C('X', freq=400000) # create hardware I2c object9 T7 u+ G2 @% p4 |2 v
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
: s8 N/ p: [" g - * {( b2 r/ }2 s5 M3 [5 ^" U m: Y: |, r
- i2c.scan() # returns list of slave addresses4 R% C1 D- p3 d+ V6 w
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42% m: x# Q1 Q/ Z0 A) @- X
- i2c.readfrom(0x42, 5) # read 5 bytes from slave
* g# m' Q, v7 b, @; b0 f8 G" h
5 ^. _6 d+ T, k$ i: j- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
; f5 c9 k: p( B9 Z R9 ^! l - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码 6 @$ r# i8 Z) D$ J
* S- I# C/ H+ H I注意:对于传统 I2C 支持,请参阅 pyb.I2C。 ]8 ~1 h; P0 j: T/ d: l
I2S总线参见 machine.I2S. - from machine import I2S, Pin/ [, L9 i9 L) I" O1 A( w; Z6 K
- ; r& I& Q( }3 y5 \& W4 j7 K6 q6 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
) y" E+ w& y, W3 m: r - i2s.write(buf) # write buffer of audio samples to I2S device
; w4 a D7 [1 K6 k - , w w8 A; m! t; ~
- 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
% v1 {( F! W3 c) P2 @& R - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
; N$ K: y9 V5 S! o% N7 M$ e0 BI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 ! |" Q4 R7 Q; Y( [" {; A& W' V% l
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN5 v- `) K) f8 L/ W# b8 C
- ( q& ?! n" Q& \
- can = CAN(1, CAN.LOOPBACK)
/ E& F V }2 m7 `9 A; r, N - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
# w0 q1 r& j8 l( ~8 w/ R - can.send('message!', 123) # send a message with id 1231 i- i9 Q8 C6 T% ~. o6 h
- can.recv(0) # receive message on FIFO 0
复制代码 , [& \5 t3 l8 h& z, _+ W( o
* U: {4 N/ [7 Y/ o: O
内部加速度计参见pyb.Accel. - from pyb import Accel! d. t; I7 I0 ], }) w( l, [
- " Q& ~! L6 f1 r0 ]8 }8 W
- accel = Accel()
/ z3 c8 Y6 n6 n; K9 Z - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
* I1 B' r2 |: E& f- H2 e: ] B, J
|