pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: ' |3 n! r+ l6 B! O) x! q4 P' D
通用板控制见 pyb. - import pyb
/ F' Z" V& }+ J# Q - `3 x/ u5 B& @0 H8 J7 O
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
% `* Y7 Z: T/ ]! r% r - pyb.wfi() # pause CPU, waiting for interrupt
- v8 z. p+ [* e& |+ ?% I( _ - pyb.freq() # get CPU and bus frequencies
* `, m3 k1 ]0 F! V9 y! l) l - pyb.freq(60000000) # set CPU freq to 60MHz! y0 j' R7 H: |
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码
7 L+ U ` m& ~* v( E
& N. L" ^) f1 w4 }- B8 b延迟和计时使用 time模块: - import time
4 U% D" U0 f; C6 Y3 B! R8 [0 M
4 M& h5 J, }) n5 f6 [ z- Q- time.sleep(1) # sleep for 1 second& O2 e/ g( [! T% T/ ?! g1 g/ ^7 U
- time.sleep_ms(500) # sleep for 500 milliseconds# [7 N, K; n* }% ~6 L
- time.sleep_us(10) # sleep for 10 microseconds
8 X8 I$ n# t: n+ q! H6 O) c0 b2 L - start = time.ticks_ms() # get value of millisecond counter
' u: O( A' q& @: F - delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 " G2 ]1 A0 w5 u8 @5 W: b8 @
6 u& M1 L+ A( a
内部 LED见 pyb.LED. - from pyb import LED- V- b! V; P& G/ |' L5 X
- ( U( ^1 ~# \. N0 c1 ?: M
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue7 S1 f+ U0 ~, L, Q8 i8 ?$ _# G
- led.toggle(), e: P# p# H5 S, a( ]* m6 y
- led.on()
2 Z$ x" O7 s! J- A1 b9 H - led.off()5 M! o+ k/ o8 X6 R8 u+ `0 O
9 ^4 r% q5 X, D! u. p4 d6 c- # LEDs 3 and 4 support PWM intensity (0-255)" k! T0 m" f# d! f0 c
- LED(4).intensity() # get intensity: i5 \" l6 R0 l! ~( d: _/ l0 ^
- LED(4).intensity(128) # set intensity to half
复制代码 2 M7 R+ ?5 e% I1 K. u' E
" l. H; j" g. S内部开关请参阅 pyb.Switch. - from pyb import Switch; [. h4 N9 Z: {% {
. C# X) h( r* o" y5 y) ~- sw = Switch()9 Z0 G8 @. k" u
- sw.value() # returns True or False
% \/ W) _, p# T2 y8 Y - sw.callback(lambda: pyb.LED(1).toggle())
复制代码
9 ^/ E( @. Z& S' G
* t2 O0 j/ j1 F5 z引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
k0 g/ g6 Z# u2 \2 w
* r7 D$ X2 }& b7 P6 X- p_out = Pin('X1', Pin.OUT_PP)
: R4 Z B; w/ l7 f4 a7 G - p_out.high()0 @' [4 U L N, x; I$ I
- p_out.low()) F7 `' ]/ N( \7 Q
& l3 Z) B- R" A' @; n- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)8 v1 D$ h- k- ~2 Y. _+ {- V/ q# p
- p_in.value() # get value, 0 or 1
复制代码
) w4 ?3 Z1 D7 s# j
2 W( ^+ T; u3 p7 B6 |; t: |( Y伺服控制请参阅pyb.Servo. - from pyb import Servo
' D0 Z! u6 }, f5 \: ` - * m$ Z( ?2 w& B$ g/ |
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)2 o; p' A6 ~ e7 u
- s1.angle(45) # move to 45 degrees: V E, J& _: D$ n
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms
& p8 G* z: L& p. d. t - s1.speed(50) # for continuous rotation servos
复制代码 # y: x o) k/ k/ h i
. v& O4 u8 T0 Q# M外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt$ u D+ R+ _7 O' |
& n# Z$ G& z M) Z; K' g- callback = lambda e: print("intr")
& ^9 U3 B: a9 t/ P+ Y1 _3 k6 }' f" O7 I - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 5 S7 x) |/ T! u) F& m* Q
( V5 r) H' a K8 ]. i9 g
计时器请参阅pyb.Timer. - from pyb import Timer
. e! E. p4 g6 D& b/ a+ ~, M" X/ n4 q - m1 y/ r5 |' ^2 i& L! \2 ^4 ^$ Z
- tim = Timer(1, freq=1000)
/ R4 A) u7 h& A+ ?: m; \ - tim.counter() # get counter value
, T! y$ \5 E5 N" m( P, C$ T - tim.freq(0.5) # 0.5 Hz
1 V4 Q& F) _, |0 p - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 6 S6 `' V1 A4 O# @5 }, a
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC+ K$ j% @: a: k. t+ {4 l) l
/ g( S$ ^& c4 s9 N2 i- rtc = RTC()
7 J/ j) [- \, \% K! m. Z" N - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time+ W) J. H0 i& k" o: ^! l0 O
- rtc.datetime() # get date and time
复制代码 - b5 B' H% E I) x8 w- J# k; A
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer* a) P3 p9 R: ~& @
& L9 U+ D& m2 a2 o- p = Pin('X1') # X1 has TIM2, CH1
0 C" ]6 k5 c* A' C - tim = Timer(2, freq=1000)$ p5 y$ Z% X, [! e& I' t
- ch = tim.channel(1, Timer.PWM, pin=p). a/ ^6 m: p) ^, x9 R$ ~- ^
- ch.pulse_width_percent(50)
复制代码
) P) m1 X) L' `4 W) LADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
@3 \3 r, v, e6 g. s. J - 5 A# X F" a! F5 a
- adc = ADC(Pin('X19'))
3 l6 h, A# p, W* [( `0 } - adc.read() # read value, 0-4095
复制代码
- @( P% |( h3 |1 [: C
: n" t( K& x3 b; i9 VDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC& X0 @0 g0 _& u9 ]: X
: X7 D4 e. X4 ^& L/ d- dac = DAC(Pin('X5'))
! @# e" z3 P# W6 w9 A6 }* \ - dac.write(120) # output between 0 and 255
复制代码
$ k+ v$ U1 @! b1 h4 Z( n8 H1 }
5 L' \6 H0 d; o0 g$ I' uUART(串行总线)请参阅 pyb.UART. - from pyb import UART
4 n% _, N; ^8 ^0 _# k; S. G - . S( n% P/ P+ i1 c6 j
- uart = UART(1, 9600)
+ a$ Y& ~6 |5 E/ U: E - uart.write('hello')
8 @) W, f/ t2 l F- @ - uart.read(5) # read up to 5 bytes
复制代码
, S( {% G6 ]; [, m6 ^: D5 Y3 R* E8 ?& d/ z# B$ |8 R/ t
SPI总线请参阅 pyb.SPI. - from pyb import SPI
5 ]+ e9 b9 | l' l
7 t' V# _/ n$ J( \! C- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
9 J5 N+ m; i d+ h" {, ]; @ - spi.send('hello')
, G/ C, u M5 P - spi.recv(5) # receive 5 bytes on the bus
/ C$ J5 o6 ?+ t: B. D* }% }9 A - spi.send_recv('hello') # send and receive 5 bytes
复制代码
( I+ d ^! n# T. P2 g; o( |0 }
: m" u t3 Z$ ~/ j2 K6 WI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
- m O: l: @( N1 J0 |
* ^) f1 b. a2 |- i2c = I2C('X', freq=400000) # create hardware I2c object
5 B( t1 R z+ N" w2 @3 J+ o8 \# K - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
; Y0 f6 @( ~# d3 I; j
% F3 a9 q6 V6 J$ V6 F# g6 O- i2c.scan() # returns list of slave addresses
6 o3 B, ]' J! e4 ~2 l, { - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42+ j4 ]7 ~7 n, {& d6 [# E
- i2c.readfrom(0x42, 5) # read 5 bytes from slave9 o- R1 c6 F4 g7 V
0 V) D/ {. }: H. T- b- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
3 o) q! D& z& Z$ S4 k9 n - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
* t! ?' A* Z9 a) E+ A3 w4 ?! G+ a3 h* O r
注意:对于传统 I2C 支持,请参阅 pyb.I2C。 , D% u8 M4 N& e. @( Z
I2S总线参见 machine.I2S. - from machine import I2S, Pin- D7 y, v7 P) A' B4 N
9 K) x- w) h4 }* ~. K* r7 h9 W% M- 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! V. n7 b5 w1 t/ E
- i2s.write(buf) # write buffer of audio samples to I2S device
' K7 w2 ?4 w) J6 C - : J; j" i, o. Q( a8 z1 y' A
- 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$ x# i; p8 p# G& C2 a; g7 b7 X ?
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
4 s4 o& J5 j% g, y$ FI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
" Q1 [1 q% d2 q* f4 g1 ]CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN I7 `: q4 N1 k- |! U3 ^# F( G6 I
2 R1 o, H! G0 V% Y; \$ V- can = CAN(1, CAN.LOOPBACK)/ D7 J6 l+ w2 R! v1 }, V( I" t
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))7 F& ?. \ s7 T# k
- can.send('message!', 123) # send a message with id 123
9 \( ~% z7 S" Q$ F- Z. R - can.recv(0) # receive message on FIFO 0
复制代码 . w' ^ s; }2 C
) `) u# ^7 \# g% U$ R; u! s
内部加速度计参见pyb.Accel. - from pyb import Accel) n$ V3 H" M! U" @& S3 x
- 0 |7 i6 u. W D% G
- accel = Accel()
. z6 }7 X) w: }0 y - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 / k# c7 K5 `5 D& @, r, ~6 L e
$ R/ R) i t- @1 @ }9 i; ]$ M8 Q; R% `6 g |