pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: + H, d# J* o6 K, Y! }( ]% a
通用板控制见 pyb. - import pyb
5 {! u$ n+ J) n# u+ x b) s& c, `
3 m( F& s* s2 y- N* l, F* b# |- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
n l: r+ f% J2 ^ - pyb.wfi() # pause CPU, waiting for interrupt0 ^) y1 Q9 V0 H0 x4 J9 a
- pyb.freq() # get CPU and bus frequencies
8 y$ ^ D& `6 L. q# {# F3 } - pyb.freq(60000000) # set CPU freq to 60MHz2 |6 d' c, P1 c& h; K R
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码 % K7 v+ i; s* G" C ]6 B! j
9 v; j% j3 s" m* _% }6 R延迟和计时使用 time模块: - import time
5 ~5 q1 W7 L6 S - 9 o' e; m# \& i( N; V8 @7 p4 J
- time.sleep(1) # sleep for 1 second+ P1 w D1 m3 N
- time.sleep_ms(500) # sleep for 500 milliseconds
3 w( ]# \( h$ D2 n5 |4 e- T - time.sleep_us(10) # sleep for 10 microseconds2 m) X; t& v5 C: Z1 f
- start = time.ticks_ms() # get value of millisecond counter
( M6 a5 R0 O. Y- N$ H - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
( |) i+ T4 y+ W; G. b+ O: A& G. }5 ^5 J
内部 LED见 pyb.LED. - from pyb import LED
! w0 Q; o0 y% ~6 x4 k2 ]4 Z - , { M* Y1 [/ t: J3 `9 ]
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
' @& r1 ^' W7 I1 [ - led.toggle()8 c8 b; j* o' W' K
- led.on()* W9 U: n% I7 {+ b: H. Y4 v
- led.off() q G E+ H5 X$ R
! D* B9 U0 R9 z, ]& D% y- ]( A- # LEDs 3 and 4 support PWM intensity (0-255)
7 p1 X: J6 Z; z: u# r& v - LED(4).intensity() # get intensity
; ]+ D4 Z E5 F' m$ d2 j - LED(4).intensity(128) # set intensity to half
复制代码
# m8 d1 S2 ~2 N6 p
8 ^# e5 _9 c# L" C# K) o内部开关请参阅 pyb.Switch. - from pyb import Switch
* M9 O1 f- }0 V$ E$ x - ! P2 s R4 |# K2 H
- sw = Switch()
1 ?+ w1 c# [8 s& P j2 K! H6 q; m - sw.value() # returns True or False6 O2 T: A! j* F- O, c0 G
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码
[* a; U% t: w$ e# Z- d$ m2 e) I0 H8 W( |- N
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
- h% P. @$ ^+ u1 ]! C \6 L
1 B* s: m1 N$ i$ I7 m+ Z- p_out = Pin('X1', Pin.OUT_PP)% a, J5 ~2 V0 D1 E+ i+ v. _
- p_out.high()% X- K% N7 c3 W( ?) H
- p_out.low()/ l5 P2 Z- |! I& X* c2 N0 p7 S; F8 |
- % W3 U& T0 m( P6 j2 J' p3 S7 t- B+ B% h. [1 i
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)7 `0 w$ O" t! K7 S* p: j# h
- p_in.value() # get value, 0 or 1
复制代码 : Y4 X4 I" f: j# p# V5 f3 j
$ s1 K7 w! m3 J2 c' b伺服控制请参阅pyb.Servo. - from pyb import Servo
; d" U$ w6 G2 m1 f6 Z$ v4 O - / p. O j4 l$ ~
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
" v: w r4 ?; X: M. L( ]! K - s1.angle(45) # move to 45 degrees% w8 Y% O! a) `2 m5 g8 x( y
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms
5 l: k9 i. ]% M$ L6 E% E - s1.speed(50) # for continuous rotation servos
复制代码
4 S+ _! g9 e% ?% Z
: q2 N$ W, o% t4 u; h外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
K) Q0 o9 Y8 Z" Z! J9 ~4 C - * r" {1 ?( E. A% {
- callback = lambda e: print("intr")
4 C1 B l8 I9 ~3 U - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
3 R5 Z' `! i, x$ ?! D& e
, u; H% Q9 x: z2 E/ p& [; a$ T6 M' j; y. P2 D计时器请参阅pyb.Timer. - from pyb import Timer
6 j( G X3 N9 C, ^9 P* O3 r. ~2 i9 Z - . { Y4 l1 ?$ R, s
- tim = Timer(1, freq=1000)
1 q0 Z, v& [% |7 w) V - tim.counter() # get counter value
1 P8 E, P) W% q% A& S' F) P2 f - tim.freq(0.5) # 0.5 Hz
# j9 m. k s4 `! t" y$ X - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
; f& P8 u: x- C$ SRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC; a- l9 Z6 ]& U; ?! ]
- & \6 F( k2 R' D& U( j
- rtc = RTC()) D& W4 f( H" }% i
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
9 B0 x+ p5 U; O/ H" M9 j+ L( ]2 r+ z3 U - rtc.datetime() # get date and time
复制代码
, h# ~7 B# m# rPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer1 M$ \/ U$ h6 C6 J
- 1 ~3 y) P$ I& z% S3 u0 _8 L5 A: A
- p = Pin('X1') # X1 has TIM2, CH1* Y" S" u* U9 D4 ?" P$ `
- tim = Timer(2, freq=1000)$ ^; P, {4 T- d0 p
- ch = tim.channel(1, Timer.PWM, pin=p)$ |6 q' E2 g0 T" p9 m7 [
- ch.pulse_width_percent(50)
复制代码
' z' ?! w+ U- h- o4 n+ xADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
& `5 `/ B+ D# ~4 M# t - % N g, ?9 V) V4 D( N- c
- adc = ADC(Pin('X19')) { x+ U, M& g& r7 P7 r( U' ^
- adc.read() # read value, 0-4095
复制代码 8 v0 y! C: g8 H, s
% h- a; j" v" l% U& ~
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
7 @% }) C' S/ S7 J8 E9 k; | - ?5 b# d2 z) G* D3 F6 x
- dac = DAC(Pin('X5'))* g7 X/ a6 l; P0 o8 `# d
- dac.write(120) # output between 0 and 255
复制代码
6 L4 w5 M6 H" g5 e
$ {- y8 ^% E% j. S5 oUART(串行总线)请参阅 pyb.UART. - from pyb import UART
1 f0 K; V9 D" k ~: k( ^ - 4 t; J2 Y4 N# H# z* B% G
- uart = UART(1, 9600)
0 Z2 ?1 Y- ~( ~ - uart.write('hello'). f1 w$ I% f4 o9 a m
- uart.read(5) # read up to 5 bytes
复制代码 , C$ v6 R5 \! R) b
h3 z2 p1 @% @8 q6 kSPI总线请参阅 pyb.SPI. - from pyb import SPI" P, b1 u4 f9 F% W
- m5 j- s& @( {8 \# g9 \- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)# n. B- Z7 f3 w0 M% A: K
- spi.send('hello')
) N* z, h4 X+ J - spi.recv(5) # receive 5 bytes on the bus/ {* v) {- D* A, V2 Q4 S. v
- spi.send_recv('hello') # send and receive 5 bytes
复制代码 + O$ k: G9 [" t7 B, R
! }% F* S/ d. h) l2 ?/ j+ r
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C8 ?, k; W* k1 i: m* c
- 0 @# G8 Z0 X" f4 i3 \$ z% M! K
- i2c = I2C('X', freq=400000) # create hardware I2c object
@$ {& s" s) L& m - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object: I0 U; _; p3 y- o, \8 u
" G) S# b. B( k) z* Z" f w- i2c.scan() # returns list of slave addresses+ E: }/ f, a9 A X; h/ q0 z' h: D
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
2 J: i9 J6 G# D. P5 ?9 b - i2c.readfrom(0x42, 5) # read 5 bytes from slave8 ]8 g7 d7 [# g( ]
- . `# U9 y2 N) d- T, P8 G. t
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
( i" E7 Z* g# Y( V/ s - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
5 n8 [% P0 Q9 f$ G& s; a* i. I: o3 f1 a. c! o6 }9 X$ N/ `( v
注意:对于传统 I2C 支持,请参阅 pyb.I2C。
! P( L# n" b" q* \: N5 J8 u; F. _I2S总线参见 machine.I2S. - from machine import I2S, Pin% z2 r8 e" F& w1 R' Q1 U
- ' q3 {1 Q- y! x
- 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- B! o6 y D+ P9 ~' q L/ w z - i2s.write(buf) # write buffer of audio samples to I2S device
. r$ A! l1 F1 L; X/ \' \ D
( D/ V0 M% l- e) ~0 B7 Q3 D- 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! |$ ]6 A1 `5 `/ S/ h7 ]
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
' t7 V3 i, p2 }: z# PI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
" l4 p* k& q4 v# _2 R3 P) k4 g) Q8 ]$ lCAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN+ a. n& }. d+ o" T& A( M: C
5 @( l5 [ C6 l% n, O* U& W- can = CAN(1, CAN.LOOPBACK)1 |3 q1 c% O9 k0 _- o' F$ O3 e
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
F- P$ c# D8 t, |1 Q - can.send('message!', 123) # send a message with id 123, T) a6 D, w# _7 T5 ]7 P7 }6 C) A K
- can.recv(0) # receive message on FIFO 0
复制代码
$ V& ]8 r% m2 k5 q. J5 w
9 k$ E, T1 J5 ?4 {" L' S内部加速度计参见pyb.Accel. - from pyb import Accel3 M$ B, ?0 k% Z5 n, [
- ! s& M0 ^' m# b( L5 D2 M/ v
- accel = Accel()- T, T. F, z/ _4 U6 `& P0 P; ]8 s
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
% U d3 v0 G+ g6 _/ s
% D! @, @$ Y* @7 v, e" v |