pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
* S* F$ q4 A1 w: X4 N b通用板控制见 pyb. - import pyb
' Z" N: _2 C8 |6 i( m
5 h$ Y! ?0 s. F' v- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)5 n4 K6 Y$ I! _. `' x# J. T0 Z
- pyb.wfi() # pause CPU, waiting for interrupt: d/ w. K2 K: n1 Q
- pyb.freq() # get CPU and bus frequencies& K, B: u! P/ Y S; {
- pyb.freq(60000000) # set CPU freq to 60MHz
) o0 d" ]1 o2 [: h4 S& e - pyb.stop() # stop CPU, waiting for external interrupt
复制代码 $ Z6 I2 m/ Z# d, `
- Y2 A+ M; F& }* g
延迟和计时使用 time模块: - import time
6 D R. _4 W- h - + J5 a2 R: [, K' ?1 X' _
- time.sleep(1) # sleep for 1 second
8 F3 O3 F9 o4 Q3 ^% h) Y - time.sleep_ms(500) # sleep for 500 milliseconds) m" v' \8 M& _ @0 w! e: t. t
- time.sleep_us(10) # sleep for 10 microseconds
9 c- X. b* ?5 \9 {! x/ Q - start = time.ticks_ms() # get value of millisecond counter8 D" F& H( \7 Q
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 ' x9 I+ B, ?! [! ]
! t: z, W$ J% q; m3 C8 A4 ]5 a内部 LED见 pyb.LED. - from pyb import LED
/ ~+ B* B8 c7 V
# [- z: {. V8 U% w1 o; q7 ?- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue: E9 t( |' C' |; H! F
- led.toggle()
+ s1 Z" h2 s$ M2 S/ D - led.on()% f7 p4 t' s: ^4 N6 e
- led.off()
$ N, [$ } s% B+ P - & e/ \$ f" s1 {1 z' b
- # LEDs 3 and 4 support PWM intensity (0-255)# P9 P3 s1 h3 I: W! W# D& r; J" E0 G
- LED(4).intensity() # get intensity
" m4 ~5 J7 Q9 s3 V, z4 O" g; ^5 H - LED(4).intensity(128) # set intensity to half
复制代码
: |2 R' K2 Q- X. F B) a1 Q7 l9 ^: p6 e" }2 v! r( Y
内部开关请参阅 pyb.Switch. - from pyb import Switch
4 J6 D/ A2 ]+ @" z& E1 c" s. o
/ A/ ?8 j2 ?# r" v/ g" c! G4 T- sw = Switch()
% |/ E& ]1 T# H: o, z7 o& p - sw.value() # returns True or False
9 [" }: @1 q, h; N% D: X - sw.callback(lambda: pyb.LED(1).toggle())
复制代码
" z, t- `- x5 Y. t% i. u
6 ?" a* |' ?+ W; Q W: `( B" i引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin4 K) p' ?$ w9 z$ H
) @: E! }" o. J7 V- p_out = Pin('X1', Pin.OUT_PP)
% I4 l- D) v: Z+ G: k- \, B - p_out.high()
5 H/ O& [$ F+ L! ~ - p_out.low()
9 U9 p, y5 z& J" R$ J3 Z/ { - 1 B1 S& C2 s' ^1 d% c3 @- S
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)* _5 j5 g) u R2 I+ o0 ~
- p_in.value() # get value, 0 or 1
复制代码
; s9 M# ^3 R, a/ t3 x2 h3 t7 J# n/ t5 \+ w8 U l# `8 T/ b
伺服控制请参阅pyb.Servo. - from pyb import Servo
' I- Z( F& c3 r/ `# ] - / E" W* h0 ]% A2 F, N4 k$ j
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND): U, [4 r! \2 S7 X/ Q$ r2 I
- s1.angle(45) # move to 45 degrees4 n; N) ^6 v, N% _0 ]' F: @6 D
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms& z4 v- a! }! Z' n/ x
- s1.speed(50) # for continuous rotation servos
复制代码
3 @9 l8 z* o* a% n8 n# \$ _
3 J+ p" X& d0 Q' Q" g x外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt
. S& i; b4 I( c: Y6 Y' P5 m' v - 9 w j* i; B1 u4 \+ G
- callback = lambda e: print("intr")& f6 Q, ~* }) @ e) @
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码
! i& [# {2 L; j$ m1 m# ^4 {1 t& ]% N) s ^1 [% C1 m/ M. g
计时器请参阅pyb.Timer. - from pyb import Timer
" b+ ]) \5 G. h# D+ r" N; a
5 [6 m: M. U. G5 T- O- tim = Timer(1, freq=1000)
2 {9 C, _+ v6 c/ B/ i: z - tim.counter() # get counter value
9 b, U8 j: X8 I* Y V: r: B - tim.freq(0.5) # 0.5 Hz: N; ^# v/ }3 r5 h" r3 p- B- M
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码
1 Y4 S/ h1 W) a: fRTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
4 ]. F1 Q8 ?5 e' Y) k - E# K; f4 Z* v: t" N y8 F# B% s
- rtc = RTC()" u/ n: w" |1 X6 C
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time; M* n- W" K$ d0 |2 }
- rtc.datetime() # get date and time
复制代码
7 }7 ]; |. u x8 J( a8 t; xPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
/ \; |9 a& P8 B, l1 Y5 d# v& [- o0 f - 8 R0 c( A1 {5 A2 g
- p = Pin('X1') # X1 has TIM2, CH1
- X& w6 Q/ O+ f - tim = Timer(2, freq=1000)* e4 J0 k, w0 a5 T" w
- ch = tim.channel(1, Timer.PWM, pin=p), Q- r- X3 y j3 Z* D+ K
- ch.pulse_width_percent(50)
复制代码
2 L7 p8 ?8 L5 X- m: Z! nADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
: S4 z- w0 ?* n4 ] - 2 T7 x4 M& v+ m* k! m
- adc = ADC(Pin('X19'))
@6 ?3 U2 K5 e, p' _, p, D - adc.read() # read value, 0-4095
复制代码
: U7 |, O* W7 ~
/ }) |( K) P3 t n* i& TDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
$ R$ u. l0 O$ o - 4 _7 `5 M: n4 g p0 ~
- dac = DAC(Pin('X5'))
; J$ D' Y' e% N+ ?. L7 ] - dac.write(120) # output between 0 and 255
复制代码
7 k/ K$ n$ r- h7 t! }; m7 G1 ^: [8 y3 p! B6 @9 f* Q
UART(串行总线)请参阅 pyb.UART. - from pyb import UART7 B* d6 |9 I: ~
- 9 f3 N" F' N" M1 P! i) x A' V
- uart = UART(1, 9600)
9 L% \& {- r+ r, O: M - uart.write('hello')
& B/ h/ a* K3 \# K* G: W, S - uart.read(5) # read up to 5 bytes
复制代码 8 z+ q- V$ L0 W- h4 R: l- k
( J0 k5 D5 Y/ {. _- P8 WSPI总线请参阅 pyb.SPI. - from pyb import SPI: }1 {( Y# h- L5 }$ Y p
- ' b, B |+ ^6 I3 e3 _, u- L
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
6 I# U7 B7 B! `, Y) U7 M0 s - spi.send('hello')- J8 @* h, N* R; p9 e2 \
- spi.recv(5) # receive 5 bytes on the bus
8 Z% s8 _9 ]' R7 W - spi.send_recv('hello') # send and receive 5 bytes
复制代码 3 r' z8 D' _( U9 }; c
" T K! a: W( ~
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C. r) t' U6 W1 C
# ]6 O% V# n9 l- i2c = I2C('X', freq=400000) # create hardware I2c object* F6 z) r& j1 _) e; @1 M
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object( D3 Z7 A; X' a5 e0 p4 o
- 9 x& j( Q/ N9 U# v. L) y
- i2c.scan() # returns list of slave addresses0 X4 Y' S3 h+ c1 E
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
. k, v5 t5 M' T/ Z9 F7 m - i2c.readfrom(0x42, 5) # read 5 bytes from slave" {/ L1 }7 @" S
# ~% O! j. G+ s) Q* A9 L% }- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
. B# [/ [! z% ` - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
% u; Q' q# [1 Z+ C
, m+ @& a' a" T$ a& H5 g注意:对于传统 I2C 支持,请参阅 pyb.I2C。 4 i! u, W+ Y8 `2 V0 Q5 A0 g9 ^0 b
I2S总线参见 machine.I2S. - from machine import I2S, Pin
) ?2 q& f8 o. W$ K9 c - d8 g: m) p1 |9 \3 h, u5 v( S
- 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) i8 k: q+ m6 ^ }' y- R* F
- i2s.write(buf) # write buffer of audio samples to I2S device! n1 E: H/ l8 N- p5 ?7 F2 y1 @
0 I Y% d: p) `5 k1 l+ A% h* ^, {4 f4 [- 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 object6 A: C/ R* G7 U) j8 g
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
8 t3 I E$ m# m4 `" R) XI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
$ c9 ^3 N0 N' H! \CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN
3 v. R8 M) e* L$ | g - 5 C7 S. ?* H7 G- j
- can = CAN(1, CAN.LOOPBACK)
_3 C5 b! c* }5 M" _- d - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
( |0 `$ U' E! Q0 N. k8 G! H, `" H k - can.send('message!', 123) # send a message with id 123
! d% Y1 E8 G! M0 G5 n# V - can.recv(0) # receive message on FIFO 0
复制代码
0 m: C! L1 O6 g7 E) j) @, X% m4 D
内部加速度计参见pyb.Accel. - from pyb import Accel
6 o7 C7 M' v6 ~$ ^1 ~4 e3 ^+ K
H2 ^/ {2 g. l# `- accel = Accel()
' \4 e* t: M0 h3 y5 q8 h( D7 g4 k& o - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 % E1 j, R) h M9 w# `- ^
0 @; f* t+ R. N. W `
|