pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
! j* }/ o% U/ L8 e6 O7 t通用板控制见 pyb. - import pyb0 T& o4 v; C. r
$ ?! p1 N5 R$ z& _- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
% |! Y1 k; n* P7 G$ L - pyb.wfi() # pause CPU, waiting for interrupt
5 e* y. q. V# q, b* g - pyb.freq() # get CPU and bus frequencies
* u! |8 x5 X9 ~ X( Q. \+ ` - pyb.freq(60000000) # set CPU freq to 60MHz1 D4 u# |8 D, D
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码 3 k6 t) K1 ]3 r/ N" `, H
$ B# u4 w1 C5 g' n
延迟和计时使用 time模块: - import time
' b3 B7 ^2 c( j5 ~. T9 F6 C - 9 h7 w2 m& N0 |% P* W
- time.sleep(1) # sleep for 1 second
& Q( e+ t9 B# }7 e - time.sleep_ms(500) # sleep for 500 milliseconds7 B8 p0 z+ D7 ^
- time.sleep_us(10) # sleep for 10 microseconds
7 Q: a2 T$ w- f$ J% M4 i) l1 r - start = time.ticks_ms() # get value of millisecond counter
' t% ]# ~, S1 l$ W' F - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 2 B$ g& |& R9 i. h1 N
+ a4 K0 k' a: {, e内部 LED见 pyb.LED. - from pyb import LED! I& ]. r8 d1 D% m
- , q3 l/ E. L5 D; @5 x
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
4 w0 w: V9 `/ j: z' h2 n- m0 Y3 a - led.toggle()
$ @" N! b2 |7 \+ C! G - led.on()5 Z# i2 N: P u; W+ f
- led.off()
' h7 ]! Y9 b2 I' k$ t( g( O9 V
( `) b* L# i" Z" @6 S8 ~- # LEDs 3 and 4 support PWM intensity (0-255)# }( K" P' t W3 a: V9 V
- LED(4).intensity() # get intensity
% I- B0 J. Q' Y/ R; y0 p$ |% p& h - LED(4).intensity(128) # set intensity to half
复制代码
" b! J+ a. Q3 g2 i) ~" R& \$ @; d' Y! e9 R2 c+ K
内部开关请参阅 pyb.Switch. - from pyb import Switch
: C2 m8 l* K) l( S h/ [- q ^/ o
5 ~( S+ }( j) N4 A, {! }# x# Z- sw = Switch()1 }# A# [; ]" O
- sw.value() # returns True or False
% B" s0 {& z! Y, P- H# I2 v - sw.callback(lambda: pyb.LED(1).toggle())
复制代码 4 M) m; B2 ]+ O k' [7 S. a8 L
' C" K: g- y5 [! I' d* H( l: ~引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
1 ?4 v! E8 \3 @# U/ }/ Y3 Y4 }: m# X
7 e; h& _ a+ |$ n# \* A* X& `6 f; t- p_out = Pin('X1', Pin.OUT_PP)
$ |( ^7 {" `0 ^" b - p_out.high()
7 p0 r# w! Z3 g; B* G - p_out.low()* w8 @; U9 e# K9 n# \6 W% S; d* b
- . d% ]' O& Y% v5 z5 g
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)
: o2 H5 f$ s3 P% L' Y - p_in.value() # get value, 0 or 1
复制代码 # A( V+ o+ S l( p8 J7 @3 x6 C+ N
, I& h7 i! }, s7 `$ Y
伺服控制请参阅pyb.Servo. - from pyb import Servo
! k( m, ~1 x" L" h/ u& T8 o - 4 P- o' W Y$ N Q2 }. O* |" C
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND). o# ?" T+ }, v3 K% I- u2 F% `2 a3 g
- s1.angle(45) # move to 45 degrees' R2 b+ R5 f9 e$ E! B3 t
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms
+ C; r% C: o+ z - s1.speed(50) # for continuous rotation servos
复制代码
% Q- M% V2 ]9 n4 ~/ [ K) x6 w0 |( _' n0 ]$ M+ [* b0 |5 P
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
3 c) e# Y x) X: d8 E1 ]2 ^ - / ?2 I# g. z) B2 Y6 i5 Q+ y
- callback = lambda e: print("intr")0 s A* r3 \+ ~) v F
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 9 R$ A& n3 P7 w+ L+ i; B+ h
$ l0 e0 R; Q$ o ?
计时器请参阅pyb.Timer. - from pyb import Timer# x/ o, C8 `* s! h
- + J; @' f# `9 Z4 i& \) _* ?9 @
- tim = Timer(1, freq=1000)9 g3 A; z8 {$ ]3 ]" }
- tim.counter() # get counter value5 V g6 |8 T2 k+ I' g \
- tim.freq(0.5) # 0.5 Hz" m9 b. M! h; k
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
1 D, T: g0 r" I; P( w: B# ZRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
6 a) ?+ k9 B4 D/ m: T* s. g! l0 j - ; g' @/ e: s" S5 F j% N) @
- rtc = RTC()# l# ]6 l; D% l `
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time" |' f; D8 c9 P m3 U/ \
- rtc.datetime() # get date and time
复制代码
/ C) b1 C& h LPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer+ E6 s* K8 @/ z; D6 y! r) ~7 Z v
- C, o( z' S- `" K! L6 W- p = Pin('X1') # X1 has TIM2, CH1' y) i4 T0 ^( U# D
- tim = Timer(2, freq=1000)7 f! @7 C& y% W5 d: O8 z
- ch = tim.channel(1, Timer.PWM, pin=p)3 J8 X$ H$ ?) I% R* O& s
- ch.pulse_width_percent(50)
复制代码
4 d* v% P d: G3 iADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC; w" `/ j6 f9 f! x$ o$ }
- 3 k+ ?5 E6 l9 J K) t: X. m
- adc = ADC(Pin('X19'))
9 M* f9 Y% H' ? - adc.read() # read value, 0-4095
复制代码
3 Q$ o( v9 p9 M
8 M7 }4 u% i Y# Z8 `; G& rDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
1 i* ^% @: x9 o' L- L
, y/ [& ~: a2 g- dac = DAC(Pin('X5'))
/ A: O/ h, u$ j* R) Q. m - dac.write(120) # output between 0 and 255
复制代码
! X' ^, n# u) X/ t- x0 e
* {. ]2 C9 u* T! J% eUART(串行总线)请参阅 pyb.UART. - from pyb import UART$ C* @. G. V' v: D7 o
' `! d& ~1 B, }& K! V3 t9 C- uart = UART(1, 9600)
- Q' N4 r/ B" Y9 G - uart.write('hello')
5 w- _0 p& Z4 w, ` - uart.read(5) # read up to 5 bytes
复制代码
6 o4 ] K) \1 @, l7 c" F3 o* Z# z# T' L* W
SPI总线请参阅 pyb.SPI. - from pyb import SPI8 ^! p, U, O4 g
- " I) X8 h5 b8 q- V8 ^
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
, ^* n% X* k6 D6 x0 o0 R! q! G# B - spi.send('hello')) d* U3 }" Q9 V0 C
- spi.recv(5) # receive 5 bytes on the bus3 Z; X3 G A8 O }7 t- `" i8 h
- spi.send_recv('hello') # send and receive 5 bytes
复制代码
8 c9 U( [' u. ?, n" H/ c, d1 g
, ^7 F/ U9 {, v) _6 |2 ?1 qI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C- Y Y- g j3 }1 c9 x! f) b
- # c6 Z4 z" }9 ~4 k" I x- }* P
- i2c = I2C('X', freq=400000) # create hardware I2c object5 i3 Y! ~3 X9 M5 E2 x: e9 \
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object4 @/ Q" Z) O% a% _% ]- J0 q
- 6 d: n) q5 P+ O( @+ k% d: W5 P
- i2c.scan() # returns list of slave addresses/ o# P! V Z+ V8 [8 m2 ^
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42" v3 G; p3 Z3 W
- i2c.readfrom(0x42, 5) # read 5 bytes from slave; f! B4 B/ B/ m) b2 H. `
- 3 u, X0 Y/ }3 e0 ]
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x106 b7 f6 x9 k) s7 W7 {: A3 R
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码 ) ?' i/ n+ P. \
6 n7 _1 E0 f1 |, j) R8 I注意:对于传统 I2C 支持,请参阅 pyb.I2C。
$ C. O: A& O# E/ Q6 R/ jI2S总线参见 machine.I2S. - from machine import I2S, Pin4 u5 o5 t3 |6 P" B) c8 f! y8 K) Z% A
4 n9 Q& P9 C, E, x& ~- 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
- H0 e4 Q8 ]( U" i4 ]: B - i2s.write(buf) # write buffer of audio samples to I2S device+ A4 u' U7 Q8 Y- L. r* q* h; a
- % p- o+ K! j4 q( r0 R2 h
- 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( y) `* n, T0 i5 Q4 B9 L. ]
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
9 q9 V V2 n; s$ w! X- AI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
8 o- K& s. J; C9 zCAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN1 G0 \- c/ C; \
: M2 z5 Y9 z6 P; l- `- can = CAN(1, CAN.LOOPBACK)/ c! W& ^: c+ c) Y- b5 k; M# u
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
& ]" b! `6 ?" L, t1 j* B - can.send('message!', 123) # send a message with id 123
2 X9 N e- G3 P8 w - can.recv(0) # receive message on FIFO 0
复制代码 : W' s' Q$ r$ [& v3 a1 i
: S: {& m4 H6 {7 Y) B: u$ a内部加速度计参见pyb.Accel. - from pyb import Accel
1 _' R: {# F/ _' J - 5 p0 y6 Z$ ~. q. U5 j2 _+ t
- accel = Accel()
4 Q* Z3 U" }+ B. J+ s0 a - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
' i: Z; L5 T0 r1 s! [& l* O6 H
N5 ^& V3 G& n# u$ k; }, [8 ` |