pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分:
) P* ^) n2 ~7 |& ]$ z6 y, b8 R通用板控制见 pyb. - import pyb( R* T7 K8 S" B' T! [2 j4 X
- * t' c% |/ Z9 A( C) X
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1); g. M0 \. ~9 s; |
- pyb.wfi() # pause CPU, waiting for interrupt
6 q) C" P: h" q$ ` - pyb.freq() # get CPU and bus frequencies
h7 z4 X$ ~& s) s, p( q- U' S6 L$ }& d - pyb.freq(60000000) # set CPU freq to 60MHz+ W- j X0 a8 f! q6 U/ h/ m
- pyb.stop() # stop CPU, waiting for external interrupt
复制代码
: L$ h. N; }& |% D$ Q% X- V1 x; ?) ?8 P0 w
延迟和计时使用 time模块: - import time
8 {4 D% v/ n# N7 C4 z' X
V/ ]8 y& a) ^% v- time.sleep(1) # sleep for 1 second0 Y( o |5 S% L( @) e$ F) @
- time.sleep_ms(500) # sleep for 500 milliseconds
, p/ ]2 z+ p7 }) D* V( C3 t% C - time.sleep_us(10) # sleep for 10 microseconds8 O5 V' Y8 \' k3 b, J& y
- start = time.ticks_ms() # get value of millisecond counter: m# T6 Z/ ]8 ]8 Y$ p& q
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码 5 T" n5 [" f6 e4 T5 l
0 ^5 c: [( Z8 ]0 S2 @5 S- m内部 LED见 pyb.LED. - from pyb import LED7 n% F+ C6 z" c" e- d9 x. u
% u& d! U% @& p& _* n" y; X- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
: D6 c2 I- f( }( i0 R6 z2 ~ - led.toggle()
+ @) d. F, T7 i+ Z* G6 l - led.on()6 e1 `# z* O0 Z( g
- led.off()
8 A: Q4 w2 i7 v9 C- V
8 ~! P6 |( k9 g# ] a1 R$ G2 O0 z- # LEDs 3 and 4 support PWM intensity (0-255)9 g3 [; C% J& Y O0 d5 n
- LED(4).intensity() # get intensity2 s( n, M1 y; M5 L& q
- LED(4).intensity(128) # set intensity to half
复制代码 : j3 E! [0 e) E8 W# Y
/ J. r1 ~4 |( j1 R( N, k内部开关请参阅 pyb.Switch. - from pyb import Switch
7 t( l$ |& y( y+ I* L* q% w
* l* i& o5 ^1 _6 ~6 y# F- sw = Switch()6 B9 Z4 G# I. y3 ^- V& y
- sw.value() # returns True or False% G9 j: M# c; p- i
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码 * E ]2 q, I) a4 Y
& N& S" i O0 a& \! f, y p9 O引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin$ D: k# }8 w) g7 q8 x) u
- + x- B0 A9 J( L8 q* a! R7 s
- p_out = Pin('X1', Pin.OUT_PP)- T, T0 F1 R o5 N8 D- b# Z: V
- p_out.high()( H) J$ R( j# o6 F( U' {
- p_out.low()/ @; R- P7 c0 y& g& w( L
- |/ @. s7 f. N3 D) O# o
- p_in = Pin('X2', Pin.IN, Pin.PULL_UP)8 F* X" U7 k# T7 v' z+ c
- p_in.value() # get value, 0 or 1
复制代码 ; V+ q# e& ]9 r% x
' e7 o: E' G3 G9 y# `3 U+ U伺服控制请参阅pyb.Servo. - from pyb import Servo$ d) p: A- Z, h
E& r5 m5 q8 N: F: B& o7 s6 f- s1 = Servo(1) # servo on position 1 (X1, VIN, GND)0 I' t- R, i1 X
- s1.angle(45) # move to 45 degrees
& G5 ^8 e; H6 [( H2 a' j% h3 h - s1.angle(-60, 1500) # move to -60 degrees in 1500ms
+ k: A2 P2 F/ [( B - s1.speed(50) # for continuous rotation servos
复制代码 5 o/ v) m9 ?1 k' v
6 d. r; n T' j U
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt- Q/ W/ `+ R0 |7 Z, A" R1 R. `
- ) R# Q3 y' f3 l' S6 o4 m6 D/ w: k0 [' [
- callback = lambda e: print("intr")3 g6 }- {3 e$ G% E7 R
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 / G: }% \9 `# o+ b3 y& x
2 j. C' Y9 h+ S7 e5 V& Y计时器请参阅pyb.Timer. - from pyb import Timer$ X7 Q% S1 R0 Q& Q8 |; [
- ; }) f+ ?0 O! ]. a6 e7 \
- tim = Timer(1, freq=1000)
$ ^6 k1 K+ I; E9 g1 j - tim.counter() # get counter value
, ~; W/ ]3 @9 \6 a& F* M. ~8 m - tim.freq(0.5) # 0.5 Hz
1 q4 J9 f3 s. p& V2 v L5 |0 K - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 , Q9 V: K% W2 {$ d! ^: T& J
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC
$ x2 c4 c- d+ T5 F0 h( N( p
& X! k* b) A6 S: A# P+ k$ H- rtc = RTC()
% {* Z) E! s+ c+ Y' t6 U4 n% {6 O - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time( |% Z& \ f) L! u
- rtc.datetime() # get date and time
复制代码 5 g. _5 B0 W9 G" N; ~. j$ y
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer
) F: g5 r/ S6 Y5 V0 M - ; ^$ u7 A6 f" f/ Y$ M5 ]7 W
- p = Pin('X1') # X1 has TIM2, CH1! ?* D% ]# P' N8 B" p* ~( [& m
- tim = Timer(2, freq=1000)
) S# g' }1 \7 ? - ch = tim.channel(1, Timer.PWM, pin=p)* y5 Y' k" }5 F' {0 d
- ch.pulse_width_percent(50)
复制代码
; C! j5 {# Y8 m1 G$ C" {6 kADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC) @/ d1 Y3 D' e5 h: |/ r4 N
- 9 X% K) H3 T5 p& ?, h* T& |4 o' \- \
- adc = ADC(Pin('X19'))) c7 `4 T9 O2 o0 S$ t4 y- ?
- adc.read() # read value, 0-4095
复制代码 . s# P0 C, ?- J, j4 i5 }
$ q5 m0 z5 _0 Z9 s: J7 R
DAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC
6 O) X M- A( j b - + @ Q/ }0 m8 y: a0 b/ A
- dac = DAC(Pin('X5')), t* b* Q/ M; \! G8 q" E+ l \8 R
- dac.write(120) # output between 0 and 255
复制代码 # q( @# Z: |0 L7 T! F3 T
2 q# S5 o$ _7 aUART(串行总线)请参阅 pyb.UART. - from pyb import UART4 f, K p6 X4 D% j
- + O. [! \/ B4 p1 I
- uart = UART(1, 9600)/ z9 X: z; R3 V! R
- uart.write('hello')
7 t) `/ ]4 s, s; k8 ?1 A# @# |3 ?9 T3 b - uart.read(5) # read up to 5 bytes
复制代码 0 F5 q7 S% y4 ~1 R: h2 y9 v1 H
; h7 u0 A: }' `: Y s
SPI总线请参阅 pyb.SPI. - from pyb import SPI
0 _% g2 i# J' q J% w
O: O& \' |* D3 {- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)
2 Z5 N% B! o, m7 i - spi.send('hello')0 n+ U1 A5 _- @; E9 E
- spi.recv(5) # receive 5 bytes on the bus6 g; y9 J7 m, M. ?6 {# U
- spi.send_recv('hello') # send and receive 5 bytes
复制代码 # s; b5 e8 D# i4 y, U7 }
' P$ c Y C& G8 f% J' U0 e1 FI2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
- Z7 a, I1 n$ ^% V% e0 U! n$ X
4 h/ J! e0 M+ v2 v/ t- _7 N4 N, j- i2c = I2C('X', freq=400000) # create hardware I2c object
" Z) F* m0 @! V - i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object( J; A, ~+ U* z x
+ g8 E2 U5 Y6 Q% j# t) x- i2c.scan() # returns list of slave addresses
5 X# t7 o( K2 g6 W2 { - i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42
6 ?5 T/ Y9 j# f' L - i2c.readfrom(0x42, 5) # read 5 bytes from slave9 o) P7 Q# G4 { l0 i
9 A) P5 ~- O: H3 V- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x10
1 Q2 r6 l) I: c% z; A! N" t: j; k' T; C - i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码 " c+ R: ?* A2 V
' d: r8 [/ I( d& Z F注意:对于传统 I2C 支持,请参阅 pyb.I2C。 ! O2 ]( P/ |, p/ s. g
I2S总线参见 machine.I2S. - from machine import I2S, Pin2 _: L# O% A$ Q1 a' A
! L5 L4 k. H: Y' v# w6 Z: O/ O- 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
( }0 V" K( f; H0 q1 n8 l. { - i2s.write(buf) # write buffer of audio samples to I2S device
8 B0 e8 I+ U% r+ x* Z9 e) z7 \ - * |9 O+ N- w5 R7 o! `& `" O0 @
- 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
6 R$ V4 h' \8 m# D/ B' L8 o7 [& z - i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码
$ `- h; J* l5 }, x. _0 u0 DI2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。
, ^/ i1 O, z- S# p ?$ c! Q2 kCAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN: Q* }3 p8 R9 p7 ~, k
- ; r. l, s4 g7 ^7 t$ Q3 p
- can = CAN(1, CAN.LOOPBACK)4 H% f8 Z5 G3 Y; B5 `9 |- T$ A
- can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
/ t9 b/ T, f" z8 u1 Y# i - can.send('message!', 123) # send a message with id 1231 w! U$ H2 t' T1 E* {0 J/ d5 b2 h: [
- can.recv(0) # receive message on FIFO 0
复制代码 & b0 f1 ^# D# Z2 Z
6 p2 o) w# g2 h% y! `
内部加速度计参见pyb.Accel. - from pyb import Accel
$ \; | n; {$ h/ r
* a& P% @! c" s9 P/ |1 A) l- accel = Accel()' V9 d9 I# F* r* V
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码
. c+ h$ F9 O* N7 x' z$ }$ w/ ]3 D7 N* `
|