pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: $ @' o, ]# `+ E
通用板控制见 pyb. - import pyb
1 ?, ?, J" F' J+ C
1 L8 h& r+ I7 ~4 l0 F. M; X, W- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)) R! S" {! P& d2 f
- pyb.wfi() # pause CPU, waiting for interrupt1 U8 J3 r) W d: z( \
- pyb.freq() # get CPU and bus frequencies: z5 Y6 n8 i1 y$ z& D7 E
- pyb.freq(60000000) # set CPU freq to 60MHz
o& A+ _1 ~% i3 I6 M) ~ - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 ; J/ v( q. p7 t, J5 M7 k
! j# y; f( Q; e延迟和计时使用 time模块: - import time4 x! \4 @$ Y# x( H1 L
- V! C' J7 ~8 p, @8 K3 @+ n0 H
- time.sleep(1) # sleep for 1 second N# ^& L8 J8 Z5 i9 l7 U
- time.sleep_ms(500) # sleep for 500 milliseconds' O7 j9 F" E2 r4 J, K1 c* M
- time.sleep_us(10) # sleep for 10 microseconds' ^ C2 I/ A8 j# |6 _
- start = time.ticks_ms() # get value of millisecond counter
3 \. D0 Z! f( g' A; S; x - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
- @& l: w# h2 D9 s! |- M4 R! {( q! t3 A" b6 b e+ r9 n
内部 LED见 pyb.LED. - from pyb import LED4 E9 p: Z" }. w% O! U ]% c8 _
- " u8 N! |' v1 [: ^) J2 P% q. j
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue# D& Z* v- {7 E& x" a* v
- led.toggle(): J: q9 v" j. D4 G+ Y7 C
- led.on()
7 E$ k+ v6 B7 w - led.off()
; b7 b3 `1 n' a - / w8 ]3 s$ o/ V4 r; x7 l, ^, }. T. w
- # LEDs 3 and 4 support PWM intensity (0-255)8 R$ H* v5 Q4 t% I! M
- LED(4).intensity() # get intensity
) A: J) C* v) E# o! |& f( [' w; H - LED(4).intensity(128) # set intensity to half
复制代码 4 ?) \) T, P- M/ e
& I; y9 C0 c, x0 @, i- Y5 C1 g5 ]内部开关请参阅 pyb.Switch. - from pyb import Switch
' U3 k8 \ V/ T- e+ w: t% x6 H, m( e - , D! q; {' X+ r# x# y) R3 P% q2 G8 U- c
- sw = Switch()
: k; w* {) Z* V* n. O9 i - sw.value() # returns True or False8 y$ e b- \3 T+ u
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码 5 h( L8 V* H6 I
7 V/ T) N1 h) i$ I' _) c+ [
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
- T) f8 b# @" p5 H4 l e7 C - ' c% b: [7 q& Z% }
- p_out = Pin('X1', Pin.OUT_PP)
7 O0 D" h) F. k, T* m - p_out.high()9 o9 a) n+ o# w$ H
- p_out.low(), {7 S# M+ s$ p0 X5 ?
- : ~7 Y1 e B7 s. N
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP), A! b v/ ~; T
- p_in.value() # get value, 0 or 1
复制代码 : z$ a7 B% w( P; c( m- d& \! x8 u3 c/ R
8 j/ ^7 F- h: d% q
伺服控制请参阅pyb.Servo. - from pyb import Servo9 I% S; \' w. H8 `: \+ F O
- 5 n. p3 J5 I+ j! L$ W( [
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
4 _8 F6 M) D" `% D! S9 {# S8 u - s1.angle(45) # move to 45 degrees
0 ~. \, S% J8 H9 ^1 K - s1.angle(-60, 1500) # move to -60 degrees in 1500ms. W/ v( u6 a$ B7 f
- s1.speed(50) # for continuous rotation servos
复制代码 T8 d2 O* i& x0 d; X8 r" v) o
- s6 D" }( m! @% V" c: U
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
9 k/ P3 }( L! w8 I/ W
: a& |' Q: ]0 s1 J0 u3 F- callback = lambda e: print("intr")$ E0 L3 }9 c% o9 M
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
& d/ q; H! O$ y: |
* G+ Y! j/ N7 m8 \计时器请参阅pyb.Timer. - from pyb import Timer
) t8 c& R5 m3 a - & M$ \+ V( _5 } k+ Q
- tim = Timer(1, freq=1000)
2 Z6 z, J- U: _' x d; E - tim.counter() # get counter value/ Y+ @5 m9 J& N" z4 o" U- S
- tim.freq(0.5) # 0.5 Hz
\' z' a& y* w' p+ G - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
# @, ~( T! m+ h& B9 P6 \RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC* a0 L6 O- l6 j2 J7 S9 w' | O
5 ? s" q/ X& `& a' f$ a- rtc = RTC()
$ Y% y* R' s5 l6 S3 b - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
+ E3 \1 g0 F; ]/ t6 X - rtc.datetime() # get date and time
复制代码 ' R- z( ]: J" U9 f3 ]8 @( \, y
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer4 Y& d, _; ]8 O8 d8 w4 \
- M- k& ~5 N! ?- p = Pin('X1') # X1 has TIM2, CH1( m# K) V5 @/ e' E/ e( D8 |
- tim = Timer(2, freq=1000)& t) `% p# ~8 G( z* k% a/ w M
- ch = tim.channel(1, Timer.PWM, pin=p)
: `. W( x2 _$ g1 O# V! { - ch.pulse_width_percent(50)
复制代码 & o: [% Z$ T! `# l9 ]# m. H
ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
$ k# N% Q8 s& w1 E
2 y; o/ X+ T: B+ y- adc = ADC(Pin('X19'))
r. A. J7 F) P% J - adc.read() # read value, 0-4095
复制代码 3 X Q7 I* k& |7 V( }
8 m* u2 F- y& Y( T: H. HDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC1 @0 V2 D3 ?! }, N4 C& g) ]' @
- 1 z& Y. W2 _3 L; p' u
- dac = DAC(Pin('X5'))
1 d) G$ o+ v3 P - dac.write(120) # output between 0 and 255
复制代码
) Y! [- R5 I% l; u: E1 X" j0 S' q5 G4 ]
UART(串行总线)请参阅 pyb.UART. - from pyb import UART
- s% @( n* ~4 L" L0 Y
) |* ^* s: f4 E4 K- P3 s1 x; Q! Z: } ~- uart = UART(1, 9600), q$ Y- |- G9 n
- uart.write('hello')# l0 z: N# `& O5 ?/ {9 b- X' H
- uart.read(5) # read up to 5 bytes
复制代码
/ b/ B; }& y6 l
6 z6 }( ~/ b" |9 u0 G4 Z h( ISPI总线请参阅 pyb.SPI. - from pyb import SPI8 Y& h0 `1 o3 g H8 Z
- 0 M( G8 h( `0 e; C& \
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
' L- f* l- g% [. a$ i+ X - spi.send('hello')! s& _% Q8 E# i; \, v* K. O
- spi.recv(5) # receive 5 bytes on the bus. ?# Y0 u$ B9 w' [
- spi.send_recv('hello') # send and receive 5 bytes
复制代码
* {6 o( ?6 Q6 c8 }4 O" q$ {! W% _* O4 a
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
) g' S% O* {7 F+ G$ h - o9 ?+ q: X; g; y/ L; F
- i2c = I2C('X', freq=400000) # create hardware I2c object
. Y t; s$ l- j) ` - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
# U+ e3 Z, k& {9 w
. u( p- v& m. l4 b* ?( x- i2c.scan() # returns list of slave addresses4 }, n+ N& C2 Y3 }0 ], m# d
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
1 A: ]" c z& t( C% h - i2c.readfrom(0x42, 5) # read 5 bytes from slave5 ^) V+ t9 ]' X3 b" |3 n
- / v; q& m% S! _+ F
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
( t8 ~. P# Y, [' H8 O - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
: S6 `" F- a" ~% A3 A0 O% W1 f& s% h+ R R# u F: H! J
注意:对于传统 I2C 支持,请参阅 pyb.I2C。
6 \! b4 U) e, k& u7 XI2S总线参见 machine.I2S. - from machine import I2S, Pin1 Z0 K* w) z* {2 ~, Y
- 0 C+ ?1 f! E. V2 M- P6 ~+ g7 R" p/ c
- 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
' S' z7 v6 ^6 n; ]$ c0 [( h8 I( E - i2s.write(buf) # write buffer of audio samples to I2S device
2 W# v4 ^0 ?# Q" c7 ~3 o9 z
, c* @2 r: G8 j, k, `& P- 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
1 z! J% E" n& ~ R - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
3 ~$ a7 \+ N6 X) TI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 * _- c7 j# e* m; n- E0 z5 X
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
) J+ a& P1 j/ N: }; k - 5 R; N" Y+ r0 h9 c/ ~
- can = CAN(1, CAN.LOOPBACK)
) y/ |, F, e P1 E! N2 A) E - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))+ w% I, t& |# B6 n+ Q
- can.send('message!', 123) # send a message with id 123: l- W: }7 v' F. p7 D* q2 _6 ~* M D
- can.recv(0) # receive message on FIFO 0
复制代码 % G0 r/ s. s% [
$ {9 t! V' V; d* \; a- c内部加速度计参见pyb.Accel. - from pyb import Accel$ W$ h2 ?# d! c" r3 Q
- L1 z6 T7 a; e/ r7 Q- accel = Accel()9 _/ P; l& x, B" O7 _# C
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 : a1 R# J5 c* _9 ]
+ W, P/ @, ^% z |