pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: & |4 N4 k- h' O" s6 K9 `6 E z
通用板控制见 pyb. - import pyb' g8 q/ H! f4 ^ {9 h
) X2 ~3 }3 H3 E2 _- n9 O$ E- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)7 K" ]5 v5 A( Y
- pyb.wfi() # pause CPU, waiting for interrupt$ i# \7 F* S6 c# P' ^9 B
- pyb.freq() # get CPU and bus frequencies
- E" X; V$ P1 M4 |. f- ?4 d - pyb.freq(60000000) # set CPU freq to 60MHz
) I& ?0 @% H- l$ w+ h - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 . i6 T& P6 l! N, E
5 K, H/ i' N7 |, j
延迟和计时使用 time模块: - import time& {0 t8 D: u; v4 J2 g- A9 D1 @/ x
- ' G; U/ r, M0 ~+ }+ [/ ?+ U! J2 H' ~
- time.sleep(1) # sleep for 1 second& d6 h% f! }: v" Z+ H
- time.sleep_ms(500) # sleep for 500 milliseconds
) g2 d) Z1 p* U - time.sleep_us(10) # sleep for 10 microseconds/ \( i& ?- C( |+ v
- start = time.ticks_ms() # get value of millisecond counter+ {3 Y: d* B4 m9 c f; [
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
2 P/ \' D: p& x- l$ ]9 R9 i+ k, i* j; n& I& B8 F1 G3 p' S7 ~
内部 LED见 pyb.LED. - from pyb import LED) g1 i0 ?5 ^) X7 ~9 Z+ S
4 l3 _, P# F1 u" i7 ^( B& n, k- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue2 x' B) d4 x3 n% U) _# v# U
- led.toggle()" ]! `8 r. s* s2 w. V3 F1 Z. o
- led.on()
q ^5 E5 v, f8 C! C" E, ?& r) c - led.off()$ c( R) f; } k
: z; V0 Q5 Z- `6 r- # LEDs 3 and 4 support PWM intensity (0-255)
# E( ]& l1 K" v6 j8 I# o4 r+ } - LED(4).intensity() # get intensity
+ n8 M: @0 n$ K" g - LED(4).intensity(128) # set intensity to half
复制代码
( V9 V9 M& }1 M( t' n$ Z+ W/ U3 A! c" Q; a* L6 p; [4 |( k7 c" N
内部开关请参阅 pyb.Switch. - from pyb import Switch
$ r: [( ~) Z$ C- q - $ e6 m+ ~1 j: x3 v* K
- sw = Switch()
Z8 @+ _. [+ m4 o' M - sw.value() # returns True or False
3 Z& I- |* ^8 j. F5 N5 s - sw.callback(lambda: pyb.LED(1).toggle())
复制代码
% H' S6 t, [1 ^0 _- W# D- G* v4 U" c9 H) l; }
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin1 `. ^0 j) E4 U5 A' ]
; ]9 n0 V$ _: q n8 S3 \5 h- p_out = Pin('X1', Pin.OUT_PP)
% t. C: B! d* p3 [! \1 @# h& y - p_out.high()1 c$ S& @8 p! W g2 z! v
- p_out.low(); ]' Q$ ^; u \/ l- _
- V( c+ o6 b; k! U. |9 {2 T: x
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)6 o& e' h) @; t, L8 c# Q: O
- p_in.value() # get value, 0 or 1
复制代码 `1 b# P6 q* I- ?
0 Y: M' S; o2 {& H* V7 t伺服控制请参阅pyb.Servo. - from pyb import Servo
u; c L+ A1 d2 q6 C5 c5 q - ' I7 K& t( m+ e# z. C- B
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND): z2 z9 v9 L3 J% j3 Y7 h. M4 m
- s1.angle(45) # move to 45 degrees1 ~; [2 s( z5 d" A; a
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms
+ z! {# j, |+ ]* l - s1.speed(50) # for continuous rotation servos
复制代码 4 |" c: o) c, r3 p+ A/ I
6 x$ v% Z1 i$ t4 \, x; j外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
( I- e( Y0 D* L, l" O4 C1 P) _+ ? - & B/ `1 f: s, [, i X7 A
- callback = lambda e: print("intr")
0 G* ^) s0 e- t2 ~2 x, j7 f - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
b8 A V- P- Y- j& N% V: F6 b4 y- X7 ]$ K9 X
计时器请参阅pyb.Timer. - from pyb import Timer% b5 @ u( i+ g5 u/ n
6 A6 U l8 `2 j4 ?- tim = Timer(1, freq=1000) V" [! [" e) H( C
- tim.counter() # get counter value
Y" c* @7 S* L: M - tim.freq(0.5) # 0.5 Hz
2 Q+ t7 r* [- B. |* T7 J2 h3 g - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
W+ J# C; [" D% j" bRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
6 {; o" L: V( m: d
5 W7 P9 t* u0 f$ @4 W w- rtc = RTC()
! v) L! y+ b9 G+ B - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
7 b- l: ]9 _: u& L9 y. ~& T9 N - rtc.datetime() # get date and time
复制代码
. |8 f9 r( Z' b6 UPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer; X% o9 j, ]7 e' I
- ! _& B0 {9 k. D5 Q6 o* ~ @
- p = Pin('X1') # X1 has TIM2, CH1
4 O4 N3 M0 E) w - tim = Timer(2, freq=1000)
& e# D- _, C$ x1 }/ _$ d, n7 l - ch = tim.channel(1, Timer.PWM, pin=p)% G( P H# f$ \3 S/ d- v- _' f2 d
- ch.pulse_width_percent(50)
复制代码
4 p6 M( F9 w+ X, Z7 L, }+ pADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC2 T" z' ?) r2 m, \3 T
$ ^# t, T$ I1 }% e, V9 e, D- adc = ADC(Pin('X19'))* E" m% D/ q2 N8 L* x/ Q
- adc.read() # read value, 0-4095
复制代码 $ U1 i# u5 @6 @% w' T
$ q$ e! U6 \ j: g2 j0 z" q
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
9 ^; Z! B7 ^) C+ a6 ? - / Q. a- U% W- y& m" j- L
- dac = DAC(Pin('X5'))/ k' }4 p/ M' W- N% l+ x) c
- dac.write(120) # output between 0 and 255
复制代码
% g# V' \* x) y5 D7 G6 x7 }4 |% H4 C2 P9 n# x& a, F- ?# u
UART(串行总线)请参阅 pyb.UART. - from pyb import UART
/ ~, C% B6 p* Q2 Y
! l0 }0 }# w' F7 ~! F4 _- uart = UART(1, 9600)
* B4 e7 |) U6 d% ?* v0 T$ G - uart.write('hello')
- i3 l% i# Z0 W6 w: j x) R# L - uart.read(5) # read up to 5 bytes
复制代码 " A( a4 B1 i9 K# ^! \9 z2 e& y( ~
* A/ O" }2 F. W" F- J5 M, XSPI总线请参阅 pyb.SPI. - from pyb import SPI- }' c7 U) v& H% V: ~- l7 K1 L
4 i3 r: `, n) S' q- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
, @/ D" H* ^+ ]: d/ q! O, y/ {& N - spi.send('hello')
\+ V; r9 X7 ?$ Y% r; e - spi.recv(5) # receive 5 bytes on the bus2 `. ~% V# ]/ W; E% o
- spi.send_recv('hello') # send and receive 5 bytes
复制代码
; K! l' l5 ?2 x6 G* g0 K+ x! T+ t. h; @- s8 U
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
* R+ ] f* m6 Z0 K) P; O
' F& a; V9 Y1 C+ ^; [- i2c = I2C('X', freq=400000) # create hardware I2c object+ s l* E; l: v+ c' K/ c* L
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
9 D8 W/ a8 k8 H* _% e" V, B+ i
+ F+ S5 A5 \- G$ T# Z# V- i2c.scan() # returns list of slave addresses
0 U9 E7 a$ i/ ?+ ^. N - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42' i6 F; v" u& Q8 e$ S3 i
- i2c.readfrom(0x42, 5) # read 5 bytes from slave
# i5 B7 H9 I l' S' g; t; v. Q2 Q - 7 w3 Z5 o8 |' G$ s# {/ ]
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10* e) [) }, L4 u3 L% J
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
/ p4 X* t: f6 j% V9 A3 M o0 s! h' `; i5 S9 k1 K
注意:对于传统 I2C 支持,请参阅 pyb.I2C。
Z: o# g1 [! V% cI2S总线参见 machine.I2S. - from machine import I2S, Pin
6 Q5 [; `1 G3 i3 ^6 d: d. e$ F
5 s( z% f3 q" ?$ v- 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% Z% M) e4 U$ }6 K
- i2s.write(buf) # write buffer of audio samples to I2S device" {& \3 b1 ]- ^3 i2 f
- 6 n2 B# R/ r9 f$ Y: N2 }" F' 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
u! e1 L6 |8 _7 F( s - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
\5 g- ^3 G) y- @, A% j& q/ bI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
# X: G4 n1 K* }* p* t* ICAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN- O( N* Z0 \; r. m3 l5 X$ k
- 3 ~% O: n2 a( B8 z- s2 N
- can = CAN(1, CAN.LOOPBACK)- [% d" U' \$ h5 @, V' [, U- j" X
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
+ G) }6 e) ?+ E - can.send('message!', 123) # send a message with id 123" Y3 x" M* H/ @+ O" g
- can.recv(0) # receive message on FIFO 0
复制代码
9 H: @# w3 g% M* P. y
. V5 q6 p$ Y7 w& `7 o$ ~4 B内部加速度计参见pyb.Accel. - from pyb import Accel, w3 R9 z) ~; ^! G+ T; a" h
- 0 D/ h% m9 P! a7 `# [
- accel = Accel()+ v3 e9 k& i/ T9 I1 q& s. ?
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
8 v* F3 d2 z' A7 `! s3 b1 y
3 J( Z# m( K; s8 A- s8 s |