pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
6 ^( T4 x) O" ]1 N. u通用板控制见 pyb. - import pyb4 T9 V/ h; e) B. F
- 0 c8 g# G2 W" G( X8 m0 w0 v1 T: L# z
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
; z8 Y$ D9 I% r- T! F5 Z d1 X - pyb.wfi() # pause CPU, waiting for interrupt
( ~/ f. l4 F G2 V+ v! k - pyb.freq() # get CPU and bus frequencies2 s1 Z1 Y0 ]( c y
- pyb.freq(60000000) # set CPU freq to 60MHz: W2 K* g, U6 V; g' V; b
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码 7 y T6 Q( w! a8 [
, k- M3 y- N8 ^- l" B5 d0 P6 |延迟和计时使用 time模块: - import time
" |3 b, Y2 M! T& F$ n+ C9 O( |
* R. I/ m9 ]. F: p: e% G U- time.sleep(1) # sleep for 1 second
) [6 f3 B: C7 {$ Z% R - time.sleep_ms(500) # sleep for 500 milliseconds
5 {" d8 b: K# s$ p7 \# `: m1 V - time.sleep_us(10) # sleep for 10 microseconds+ M% [. a0 V& h ^
- start = time.ticks_ms() # get value of millisecond counter% O: n9 U' f- _% \& [3 j9 F+ }/ j
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
. A4 [. J; R) y) f! D9 F
3 O3 W/ T6 }3 a7 p9 \' g/ u内部 LED见 pyb.LED. - from pyb import LED
. A1 U9 r7 x: g6 [; p$ J8 c - ! q0 M8 b J& r$ F2 k1 P! h
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
) t& e7 s" F v! B; Q. j - led.toggle()! c! V, s: B# `( \
- led.on()
2 \. h; ^' P) U( y3 { - led.off()4 K$ e' r" T5 E5 y; Y( l7 {1 H
7 K, }8 Z$ c2 c; _% w$ d: Z! e- # LEDs 3 and 4 support PWM intensity (0-255)
! E$ I; e* F+ ^' B5 M9 E- V7 @2 Q - LED(4).intensity() # get intensity$ a! l1 L9 B' Y
- LED(4).intensity(128) # set intensity to half
复制代码
2 {! d* F) j+ P7 |
, O% _, B% N* e内部开关请参阅 pyb.Switch. - from pyb import Switch
8 a, L7 Y6 g( C- L( M; G2 o
\7 k% U2 @: B7 r- sw = Switch()$ V( S( x4 q" Q1 r1 z
- sw.value() # returns True or False. d7 ?0 M" n# T; e
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码
" f3 h$ o6 R' y ^4 ]9 b1 ^
; R* H: e) V2 J6 H引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
1 ~( m" S8 |% \1 C! V& K- }! W# B - 5 V( X6 ~, |% n9 y
- p_out = Pin('X1', Pin.OUT_PP)
2 S" L" N7 I* n( O1 g - p_out.high()/ M, U, s: C# U; u6 z/ `0 y
- p_out.low()9 g3 p; z: ^. d6 `$ |4 p
- 6 u. H% w, g! [& u8 T; W; w
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)% V2 ?/ v7 m- i( W4 o
- p_in.value() # get value, 0 or 1
复制代码 # k4 N. x; g& G
. f2 \; v B' M! m, x& a伺服控制请参阅pyb.Servo. - from pyb import Servo
$ b% J* P: n+ j/ K% q" _$ g8 ~ - 8 B( P, a/ [* A3 C' W M
- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)
- F% k% [/ p0 G t: u2 @ - s1.angle(45) # move to 45 degrees4 s8 n, H& C! Q2 s$ H! v" B$ f
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms
3 [, K& [7 @: {# g* { z+ h - s1.speed(50) # for continuous rotation servos
复制代码
' A* k3 D: s: [* C7 a E5 \
+ @" R. ]; x# L外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt8 y. h+ Z1 R, M% ?" A3 o5 m9 s9 O
- ! M1 F, M e) H i
- callback = lambda e: print("intr")
* ]! S7 k2 d* P$ q9 z - ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 ! x' d1 h& p* f: E# ~8 L; f
: r- }; B6 u+ R' c, D1 Q
计时器请参阅pyb.Timer. - from pyb import Timer) h2 s* _% |" n
- ! Y* M$ |$ B. J, ^# e6 W
- tim = Timer(1, freq=1000)6 O) K- ~4 u8 H% f7 ~ e, q
- tim.counter() # get counter value+ s* r; f) T1 u5 T. y& O
- tim.freq(0.5) # 0.5 Hz5 E4 { o7 o8 s$ o+ o5 v" y5 d- q
- tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 5 m. r; ?+ k$ f* n
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
! a, ?7 u `4 r" V* r3 X( [ - : V2 d. r4 e/ }4 `1 I) H* Q0 f
- rtc = RTC()2 r! v# ^5 r( z9 N
- rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time: P( D. x9 j1 o) P
- rtc.datetime() # get date and time
复制代码
N: o" c* J% R5 K$ U8 P7 MPWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer# I. ~$ J8 y! S2 F
% b w5 R+ d: y: a, q) l& N. q5 C- p = Pin('X1') # X1 has TIM2, CH11 E+ M% b5 `9 V" y8 o
- tim = Timer(2, freq=1000)
& _1 A# Q9 q: t+ g( q. ~* e$ Q - ch = tim.channel(1, Timer.PWM, pin=p)
% z1 W* z8 ]$ N - ch.pulse_width_percent(50)
复制代码
* V7 U9 \3 t7 g7 Q: z8 YADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC
- ~. h6 ^/ I% k; r' y# X - & A1 J: J- E8 O! H! R- H4 e0 Q7 d
- adc = ADC(Pin('X19'))
; o6 x9 j5 ]) e9 a5 B. c. C+ K/ R - adc.read() # read value, 0-4095
复制代码 6 z" x9 B8 C0 ~' O1 z
7 M: C' B+ F7 K8 r- i- }DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
3 s+ P5 k! m0 o/ i
9 j# d: B, j- g5 @. }) G- dac = DAC(Pin('X5'))
% M: O2 G) A! }6 s) c+ l5 } - dac.write(120) # output between 0 and 255
复制代码
/ i8 M0 b6 X4 S( k) e, Y4 M" S# i3 r$ E0 N( u; p
UART(串行总线)请参阅 pyb.UART. - from pyb import UART# q C. q9 Y+ U5 t# U
& o2 B$ k) _# Q* w" M- uart = UART(1, 9600)# T. ?) t2 m+ F5 R+ x% ^
- uart.write('hello')) f8 T3 F( _4 H8 H# P
- uart.read(5) # read up to 5 bytes
复制代码
7 l) X- n* q: T3 `$ x8 I: t1 `8 E9 x$ f, j% I& h
SPI总线请参阅 pyb.SPI. - from pyb import SPI: H+ K: g& k# X0 o3 e
- - p1 S6 L; p3 I" W8 W( B
- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)2 ?2 i8 P( K- v6 M% H0 {0 r4 s
- spi.send('hello')
4 N. R7 R: w1 r1 Q+ d9 q8 o - spi.recv(5) # receive 5 bytes on the bus
. E' @: N2 r3 N8 Q) X- z - spi.send_recv('hello') # send and receive 5 bytes
复制代码 4 F; _3 @1 n: s+ [
. Z5 A) N4 }6 G9 e" Z! B0 HI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C, U" f, t2 H( ~0 Y* R2 h7 F2 z
0 f6 ?5 u. J" e9 F- i2c = I2C('X', freq=400000) # create hardware I2c object! y/ B4 Z' k' e- _
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
% g) B$ r% f6 K! ~& M. a - 2 B# a. u( M! E2 ~/ d7 Y: d1 A
- i2c.scan() # returns list of slave addresses
/ H) z( N' @& B5 @: z3 s - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
: I2 I! M j- G) d - i2c.readfrom(0x42, 5) # read 5 bytes from slave; @4 x/ a4 G# J- O0 I# O
% y4 z$ H# z$ Y- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10( r& a' g. p+ _$ E( ~
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码
1 ~8 O9 h; X0 ]2 o
# o& R' C* v% a# z5 K# N注意:对于传统 I2C 支持,请参阅 pyb.I2C。
" J: K9 c4 N. p& Z* WI2S总线参见 machine.I2S. - from machine import I2S, Pin
# e0 K% h5 Y* h# u# Y0 ~ \( \1 y
" B* o& I2 p) f c: I& `- 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- H/ P$ @. Y) j9 [" c* Z2 p
- i2s.write(buf) # write buffer of audio samples to I2S device& u7 p2 H' a' C$ M
* f& C& n0 a7 Z0 s7 V- 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
; c3 R3 s1 r, _/ P$ t - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码 0 x# z& r; c1 s/ J: d* H
I2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 ) M7 A1 ?; {/ \. o7 o- ]' Z
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN5 w3 u4 T! Q3 a
- . D- U% w( r2 S" K% I
- can = CAN(1, CAN.LOOPBACK)! W0 m( w1 K9 {$ a* s5 o
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
7 N. [2 K# K4 a: k: x5 j. r - can.send('message!', 123) # send a message with id 123
) _; B! U& z- |, U6 r - can.recv(0) # receive message on FIFO 0
复制代码
7 R1 Z1 U( L2 e z5 N& ?: z2 ?8 f0 ^$ e
内部加速度计参见pyb.Accel. - from pyb import Accel2 ?( o3 A2 ?" d4 p7 t
- 8 B; `& A# }3 [
- accel = Accel()
) B/ Q! J* ]) t; N' ~ - print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 & }6 U. o2 c. s' f; i3 T- A! J
}7 G: f6 A/ ~: N1 J |