pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: 4 }8 r& J! B7 e- ~. ^* v
通用板控制见 pyb. - import pyb( a' Q/ F% e5 g1 H5 D; p
- , U1 }; V- _3 M; t% x
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
9 k& k# R: w0 E# A - pyb.wfi() # pause CPU, waiting for interrupt
5 h/ U" L/ O* x @9 R) C - pyb.freq() # get CPU and bus frequencies+ f/ ]9 D0 I. N3 Q4 ?6 L9 F0 E' z
- pyb.freq(60000000) # set CPU freq to 60MHz
. [; v; \) ]$ @$ x) q' g& ^/ r - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 ; d: H/ w2 X) ^& J4 C y5 u5 [
* ^9 o3 o8 B; H8 y; P# F/ f
延迟和计时使用 time模块: - import time+ m, r! ^1 z* Y! I# f
9 C. @* ~0 c7 p- v9 o7 [! i2 L- time.sleep(1) # sleep for 1 second
+ _& |' Y, m) _. i3 \+ V1 O2 b - time.sleep_ms(500) # sleep for 500 milliseconds
2 Y( E+ v) e4 F& T - time.sleep_us(10) # sleep for 10 microseconds
5 s3 n0 @0 k& C R7 D - start = time.ticks_ms() # get value of millisecond counter
3 @/ n( O/ v) ]: g - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 0 l$ }6 ~; O* m) c7 @; \ X6 `* N) t
% E6 i4 K! |( o2 E. A% [
内部 LED见 pyb.LED. - from pyb import LED1 D: @8 r( P5 g! {$ k
4 L0 f8 I5 G* h- Y1 s( O9 K& n1 s/ Y- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
" c5 d' e; r% b# _3 X - led.toggle()3 e5 s" W, I/ E* @) A; V
- led.on() W [, Y5 J- q, C+ v
- led.off()$ \# a9 } _- @5 ^2 E
7 ^7 E* E" W$ M% @$ j! I- # LEDs 3 and 4 support PWM intensity (0-255)" d0 r+ J, K! O+ Y8 L
- LED(4).intensity() # get intensity
0 z, K# \& F/ b: l - LED(4).intensity(128) # set intensity to half
复制代码
1 H) L% p' t" K9 R: _! s5 Q# v8 y; h* \& \/ `
内部开关请参阅 pyb.Switch. - from pyb import Switch
- \3 R: J6 |3 K" w: L9 O
6 P7 \5 D; ?7 S* a- sw = Switch()
; b" n7 @3 ` t4 y2 Y4 j - sw.value() # returns True or False. f7 M4 A9 d0 x: K. C2 {# e) X$ P
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码 0 x/ k6 ]6 Q6 }! T1 |: M/ A! U
' q; f L; k0 E+ h( W( c
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin r5 l D, c+ l4 K" Q Z
- 2 i+ K8 D6 Y% q' s0 \
- p_out = Pin('X1', Pin.OUT_PP)$ P, E: W5 O3 e$ w0 A: d8 R1 N# {( e
- p_out.high()3 J3 G8 C# |( e
- p_out.low()
* j0 V6 j( |2 d! o - : J! [2 j! H- w" {, z& C
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)9 K; p1 Q9 |! p+ A, X5 a
- p_in.value() # get value, 0 or 1
复制代码 3 C) Y8 y- P# P5 \& p- w
, M y. j" C5 C7 ~# A伺服控制请参阅pyb.Servo. - from pyb import Servo! Q+ H8 E3 C/ l# x9 E" k! o- s) `
- ; N) Z; k& B6 n, L1 [4 P+ L2 }1 E
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)) N: x& m1 z6 M! H1 E
- s1.angle(45) # move to 45 degrees
& c) Y' N+ [& \% ?$ Z* d4 n% { - s1.angle(-60, 1500) # move to -60 degrees in 1500ms
9 P* |# {! F' a* p' d# m: w - s1.speed(50) # for continuous rotation servos
复制代码 3 \0 K# f4 p! `# x7 L
0 ^1 X+ q; H3 E" z- U
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt8 b; |* N/ J" p: F0 x. @
- , a9 V* ^* w1 q$ Z1 v$ Z- o# V
- callback = lambda e: print("intr")4 J. n; w( R& n8 u, e
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
3 r4 q. _: O' p) b
9 i" j3 x3 V& a0 [ J3 C) ?' I计时器请参阅pyb.Timer. - from pyb import Timer
7 x3 R+ J9 C+ _$ X0 d* K; A - - L6 M5 Y- ^7 A2 J8 l0 \
- tim = Timer(1, freq=1000)
# k5 U0 R- O- M. l5 p9 j. v) S! S9 w; R - tim.counter() # get counter value& k- q g1 t$ w6 R
- tim.freq(0.5) # 0.5 Hz8 q% } j1 a8 L" @ H1 E
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 ) A. T0 Y4 n' V, c, N1 i9 x
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC9 H) b" u9 L8 o. P8 _
- , B4 A& |6 J2 l/ H! s8 X
- rtc = RTC()* S' A0 A. n6 Q7 p
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
B4 s) n6 q! G1 r - rtc.datetime() # get date and time
复制代码
) k' U$ _) F! o2 Y8 b, s( @3 yPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer4 U% Q! G4 x4 P% T/ j
7 ~! F! Y5 e$ p w( z* ?- p = Pin('X1') # X1 has TIM2, CH1! W" p$ r: l$ _ [- k3 `
- tim = Timer(2, freq=1000)
" o% U( C* N/ s- j/ _( G1 f9 M - ch = tim.channel(1, Timer.PWM, pin=p)
; }% O) Q" O% O% h M' ^: e - ch.pulse_width_percent(50)
复制代码 / O5 ?* P3 }8 U5 C9 {6 H
ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC( X$ s$ E& B. O S/ K' p
?7 G% f3 C6 V# o6 O- adc = ADC(Pin('X19'))5 Q) Y8 W b8 O$ N8 h- w
- adc.read() # read value, 0-4095
复制代码
- e7 q! I2 s1 |7 ]4 {+ O6 r! \- C" P1 F8 y/ f* A! F
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
. a9 M: o3 e; s - 2 c) ^/ K+ p& k* u* G `/ x. ~& s: x5 r
- dac = DAC(Pin('X5'))
8 A& |: b% L% ]4 A - dac.write(120) # output between 0 and 255
复制代码 . `5 D" E4 _( C% I; l( d ]! D( D
. M* f$ j7 k) u1 l# i _$ p
UART(串行总线)请参阅 pyb.UART. - from pyb import UART
+ V0 X# d$ X1 J9 {8 b$ [) |! @
- a$ w9 m% i5 \5 C- uart = UART(1, 9600)$ L8 l7 U: i' D; K) F
- uart.write('hello') |( \& K. U/ q
- uart.read(5) # read up to 5 bytes
复制代码 . A: y( m" l r1 T: K, u- r
1 p7 o. B; I! _2 C$ ]) }, \; rSPI总线请参阅 pyb.SPI. - from pyb import SPI* y2 @0 l/ u3 D X4 D# x# L
2 u4 G* P0 J% i- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)2 O% s# a/ m0 ?4 p& _3 [/ T
- spi.send('hello')
% r* C$ g+ ?4 J/ s) ~( Q - spi.recv(5) # receive 5 bytes on the bus
* _& u! p L$ X7 M" D3 n( t - spi.send_recv('hello') # send and receive 5 bytes
复制代码
6 s8 V5 j7 \1 w7 q" T( Z% @1 U- P: V4 C6 K, d. H* Q
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
. k1 y: m' ]! a+ r! A% R- b - # F$ s0 Z: n' ~7 g( @7 h
- i2c = I2C('X', freq=400000) # create hardware I2c object
9 @/ i) f/ K/ {: [3 K3 V - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object. q" f, F6 N2 `* |" A" ~5 e* K
8 ?- h4 Q7 S: ^7 `% n4 C+ A- i2c.scan() # returns list of slave addresses* k) W/ c2 N2 b4 ]- \1 S+ O5 z
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
- `& c* m4 f" F - i2c.readfrom(0x42, 5) # read 5 bytes from slave9 R. R. F' H% J0 J/ a' a |( O, w, `
- u# W1 c& k; r- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
5 D0 [7 ]2 T) p! p - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
" b3 P3 w# R9 f0 c" ]
2 s* c/ k& s, u/ N, q" C2 [( g, j注意:对于传统 I2C 支持,请参阅 pyb.I2C。
% \1 y( {/ [9 m8 RI2S总线参见 machine.I2S. - from machine import I2S, Pin! ] W% i0 O, I- m8 c
- 5 O9 c( P9 R% K3 M/ W- q
- 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
" J8 P [* \/ `9 x& G - i2s.write(buf) # write buffer of audio samples to I2S device+ o( r6 s' ~' F/ o8 z# w5 m1 a# b
% b2 e+ a4 [9 Y- F- 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& T# {3 C. H* @2 O! z
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
- U: B8 u8 m$ h1 Q# RI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 ) F+ Q/ e- z3 E" a
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN: d1 {2 ?7 W% b
- " x( D7 r' C* _1 J6 B# N" }* A
- can = CAN(1, CAN.LOOPBACK)8 u5 O- Z ]( _: d2 I& l
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
3 L/ ]5 {2 J% J9 W; C - can.send('message!', 123) # send a message with id 123
9 `2 A& g) v p - can.recv(0) # receive message on FIFO 0
复制代码
9 ~6 l8 Z/ D1 u' g+ X. Q7 J) s' h
* P$ ?; \1 T- I$ p: q5 C/ M9 w内部加速度计参见pyb.Accel. - from pyb import Accel" T+ A6 [, i3 }' m& B( i1 e7 p
1 c* E# L/ x4 P! f- accel = Accel()
: d$ R; G: i/ u6 Q; l7 ^' j - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 * q( u' ~9 X8 w: O. @5 m% W1 I
, W7 s. h" J' c: p, D% W- A; u |