pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
I- m& W# V! j" }4 S/ A通用板控制见 pyb. - import pyb4 a7 r7 n* N" Z- b+ c& |% e
( M1 I/ B2 ~6 j- t5 @) D' `- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
1 m: q8 W0 v ~+ r, p6 s - pyb.wfi() # pause CPU, waiting for interrupt
; P- ]' B4 [% }4 s: X$ M - pyb.freq() # get CPU and bus frequencies
1 V, g! s4 `( n9 \" w/ { - pyb.freq(60000000) # set CPU freq to 60MHz
5 K9 N3 P$ P3 B0 A* n - pyb.stop() # stop CPU, waiting for external interrupt
复制代码
+ N4 ?+ @2 [% ~: A& k4 @8 i8 {, H5 Y- d5 Y b: X4 J
延迟和计时使用 time模块: - import time6 u# l v4 @8 x
- ' S7 q# [. {- S D- ~3 l
- time.sleep(1) # sleep for 1 second A) o0 v# u% `: z4 I1 }. B6 l
- time.sleep_ms(500) # sleep for 500 milliseconds8 F* ?1 _1 b* t A
- time.sleep_us(10) # sleep for 10 microseconds- w! v, o% V( q& K3 w" n" B% h) U
- start = time.ticks_ms() # get value of millisecond counter7 \( C/ G* i" T. P
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 & r6 u3 C! n6 C8 g
1 X' v3 w& Z( S
内部 LED见 pyb.LED. - from pyb import LED
# Y0 s0 b. F5 F) z
8 k3 D+ ^4 p- w3 |( {! I1 J- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
' a2 H. K5 U8 U - led.toggle()9 v+ B4 M- ?! c4 `
- led.on()
+ g" R8 d9 `$ `/ M: n5 y# p - led.off()
) t! D' j# ] S7 P, u - ' x' m$ x9 N* q* u0 \0 }( l
- # LEDs 3 and 4 support PWM intensity (0-255)
% }2 n) q: H% ]* v' q& [! q - LED(4).intensity() # get intensity
- a3 X2 t( o7 R" \- w - LED(4).intensity(128) # set intensity to half
复制代码 & o. R$ `! r4 k0 N
8 L0 X$ u4 Z8 g7 W6 b! K0 P, y内部开关请参阅 pyb.Switch. - from pyb import Switch* U- [6 k. P9 k( l* z
- ' }+ v. E5 [; `+ r0 q9 R4 _' `3 {# l
- sw = Switch()
7 g! m5 ^5 ~2 W" Q% n- Z9 c - sw.value() # returns True or False
% j+ U4 H3 U3 N" ^" k7 u$ u0 _ - sw.callback(lambda: pyb.LED(1).toggle())
复制代码 * }8 ^+ N7 Z+ K4 W) N) o( q4 d
, ]" x* `8 S& e0 B' ?: a6 D
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
; s) U& g0 }7 r
. O. X/ }0 @. E9 k2 K5 D! N$ b# M1 S- p_out = Pin('X1', Pin.OUT_PP)
~1 T* F( n& o; G9 Y - p_out.high()
) G9 v; [% H5 j& f9 C - p_out.low()
6 W( ~5 B: ^2 b- H: i% o - / o7 n) l$ [. U$ Y3 ~
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
6 p+ w- @7 B4 w4 d+ A3 x, l - p_in.value() # get value, 0 or 1
复制代码
, I0 C C5 G& }6 d" P# J# `6 ^( I
伺服控制请参阅pyb.Servo. - from pyb import Servo5 M8 c; \; A4 K3 I" \3 L
- 1 e7 j: y4 d& A% i: q. g- O/ Q
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
+ l. O g# i1 J, L - s1.angle(45) # move to 45 degrees
9 g: A( }' |3 s S) H - s1.angle(-60, 1500) # move to -60 degrees in 1500ms
; d" u$ ~) q) \& z" V$ M4 J - s1.speed(50) # for continuous rotation servos
复制代码 % j) U; p4 Z+ A% c' ?2 E! W1 P% k
) O! w/ u8 h' a8 w+ Y: i- s
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt3 ^3 S: y) F) U8 j- K( x: I+ s
) X' O. x9 c, y: G$ z n- callback = lambda e: print("intr"), C- n2 E! g6 _% R' x9 Q( n
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 ; Q8 b1 B' f/ k: ~
9 V8 t0 C% v; K. X8 m计时器请参阅pyb.Timer. - from pyb import Timer4 O" ^4 `5 @7 b, B0 @' W
. I& }5 J( M# L0 Y, Y- tim = Timer(1, freq=1000)
" s2 F) _9 k) _; _0 P- U, F - tim.counter() # get counter value+ `3 v+ s6 Q( U4 C1 g
- tim.freq(0.5) # 0.5 Hz
* H* U Y5 k/ I! |6 r% t- N8 z - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 7 Q h1 H; s' _" Q
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
% X% O( D0 S" ~+ @$ k) _; n; E - - x' n0 D, E8 ]* ~" J, E
- rtc = RTC()
: @- e/ g2 [5 u1 y x - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time; ^" p! a+ @/ g. Q6 n* f
- rtc.datetime() # get date and time
复制代码
$ O. z+ w: f' ?3 E' Q' zPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer6 d3 t6 D) O! Y& v9 J! m' ?
4 m# T. f# n) o# _9 c- p = Pin('X1') # X1 has TIM2, CH1+ S9 w0 V3 Q6 ~$ L& |/ I2 t
- tim = Timer(2, freq=1000)
9 k1 j! H8 ]+ q" J' r - ch = tim.channel(1, Timer.PWM, pin=p)4 N8 ]; E5 X# B j7 x0 s3 |
- ch.pulse_width_percent(50)
复制代码 ( U/ `! r- a W5 D- Q) d
ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
3 i3 h6 b, @+ e# u# z+ _6 L - 0 {' x$ B& u% O* H4 M" X, k! a
- adc = ADC(Pin('X19'))7 |( z4 [7 d& Y: S' j- S
- adc.read() # read value, 0-4095
复制代码
, P/ S8 [( ~8 a' M
% N/ X8 e4 U3 ^7 R% G" jDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
1 W, g' S6 g( P; Q9 ~( T! {: E - 5 t8 T' O/ _ }9 {, Z" z
- dac = DAC(Pin('X5'))
8 k7 N. i$ U0 a0 m) w - dac.write(120) # output between 0 and 255
复制代码
3 B! U( j) m/ @# }$ E* M8 B. H) j; k: B5 m t5 J2 }2 {
UART(串行总线)请参阅 pyb.UART. - from pyb import UART, h# t) h) h! ]' j3 o/ j# `
- 9 ~/ u. s; G+ G' Y6 T
- uart = UART(1, 9600)+ V5 ?2 n# j& {# p: Q' \% [
- uart.write('hello'); K, K( k: E/ S5 l4 D" u4 R2 Q: z$ N
- uart.read(5) # read up to 5 bytes
复制代码
3 g' d& U$ X4 P7 N
{7 m; |6 l. m) }( v3 G( X7 \SPI总线请参阅 pyb.SPI. - from pyb import SPI
, S9 F- ~, ~% c0 p7 p( w - $ W! @6 v* R. [
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
" ?8 O6 [( z% w/ m) R5 f8 Y, I - spi.send('hello')
1 |0 |4 {6 ^7 y2 E - spi.recv(5) # receive 5 bytes on the bus
$ X: u6 F& z! i. ^+ j6 g - spi.send_recv('hello') # send and receive 5 bytes
复制代码 / v+ a# Z# f/ J: @# U
: M3 P5 ^3 F, m( g0 m( A! s0 ^
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
$ j% m; F9 o* M- M' \3 t T - ; `* L; k, s" Y
- i2c = I2C('X', freq=400000) # create hardware I2c object% ~% L* u7 T4 ^ u- v4 Y
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object% u: Z4 C+ D3 Y9 w) @' }% b6 K; Q
# g) r* g! X$ l7 o% Z- i2c.scan() # returns list of slave addresses- ~/ s( p9 c4 k
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42 M$ m4 Z- Z* S' T* z9 i- I- z
- i2c.readfrom(0x42, 5) # read 5 bytes from slave8 j a b* s- Z f! {1 [$ F7 |: z
- N* E8 ?8 d" s1 t7 H- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
$ X* }+ A- N$ f1 a/ W - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
) G( u1 z* ^" C4 J, X# E" N0 g3 c; q- ~$ E
注意:对于传统 I2C 支持,请参阅 pyb.I2C。 3 ]' U3 e6 w+ Y: M, Z
I2S总线参见 machine.I2S. - from machine import I2S, Pin
8 ]3 N+ Q( m: e+ M5 H
4 @2 l3 g1 w( W# J1 f- 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
( K3 L2 J3 ]! \, w4 a1 ]7 Y; k' n* J - i2s.write(buf) # write buffer of audio samples to I2S device; L: D3 Z9 B# r0 B9 s, _, \
- : \: j/ ]5 ~8 c) X& E) e) [/ [
- 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% N; C6 f, f: u j. ?( y! w2 w8 G
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
; r0 r" c/ R" ^* nI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
6 `/ h- u3 Z2 H) Z/ s- T+ x |CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN8 l( J7 [: e k3 V1 o, H2 ?
- " g5 I9 R; L/ { a
- can = CAN(1, CAN.LOOPBACK)- S6 A1 l) v) F" }% V3 X
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))+ j. b1 U6 m2 p
- can.send('message!', 123) # send a message with id 123
) w, ? A/ _9 ~1 x) E - can.recv(0) # receive message on FIFO 0
复制代码
# z1 k" d+ p( W! c k$ @+ p0 j# o/ I4 I% c9 J
内部加速度计参见pyb.Accel. - from pyb import Accel6 g: s; m' t- u: z
- b' c' P) I/ W. q7 j5 R% H
- accel = Accel()
4 V9 X _" p. ` - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
: ]/ q) n) Z% W8 Y5 l6 a+ \$ C. c( o% q7 d7 p
|