pyboard 的快速参考 以下引脚分配适用于 PYBv1.1。您还可以查看其他版本的 pyboard 的引脚排列: PYBv1.0 或PYBLITEv1.0-AC 或 PYBLITEv1.0.  下面是 pyboard 的快速参考。如果这是您第一次使用该板,请考虑先阅读以下部分: - K( g( f! ^" ]
通用板控制见 pyb. - import pyb% O, w1 j. w8 G. V. V. `
- 5 H3 C' C& A4 e: I! T
- pyb.repl_uart(pyb.UART(1, 9600)) # duplicate REPL on UART(1)
: h: @6 p d( U; S - pyb.wfi() # pause CPU, waiting for interrupt
* p& F; j$ v7 w% i% W' r - pyb.freq() # get CPU and bus frequencies
7 g8 }! X( k" ~! ]/ F" k# z - pyb.freq(60000000) # set CPU freq to 60MHz
9 d$ A" I' z H& M' U: \; R+ v - pyb.stop() # stop CPU, waiting for external interrupt
复制代码
( j) {2 V$ L, p) o
, |3 V: j7 T! H# E2 |* _4 I延迟和计时使用 time模块: - import time6 R, z0 A: `% q: X
) r9 r$ s: \% a9 L- a/ n g8 r( ^; y# ]- time.sleep(1) # sleep for 1 second3 [7 g& Y" j9 r+ T d: B1 O
- time.sleep_ms(500) # sleep for 500 milliseconds2 ^$ k$ F- d8 Y3 b
- time.sleep_us(10) # sleep for 10 microseconds5 y3 E+ J/ H1 v6 ]: M# x
- start = time.ticks_ms() # get value of millisecond counter$ D ~1 n9 `/ V
- delta = time.ticks_diff(time.ticks_ms(), start) # compute time difference
复制代码
( G5 U- H3 Z- L1 |# T
# H4 C8 ?5 g) R2 Y+ ~内部 LED见 pyb.LED. - from pyb import LED- Y/ Z$ v6 Z5 J1 w6 R; j0 j
- % |7 D$ k% Z, E1 P$ \
- led = LED(1) # 1=red, 2=green, 3=yellow, 4=blue
9 P5 K: w3 I8 q( Q/ s - led.toggle()
/ s$ K3 X6 g2 `! L2 F8 F5 b - led.on()
z r6 b( j6 s- O$ z- ^- ?& Q - led.off()) d) A$ b3 |6 w- V
- ; j/ N0 |9 t9 n! ]9 s! m
- # LEDs 3 and 4 support PWM intensity (0-255)3 b v) a5 x: \/ }0 `* s
- LED(4).intensity() # get intensity s; q8 v3 n4 [
- LED(4).intensity(128) # set intensity to half
复制代码 6 q: |$ ^- j, U' r) t `
% _) e- S9 G& j5 d
内部开关请参阅 pyb.Switch. - from pyb import Switch
* z+ J% [! ?% V6 P: M& r3 P+ U1 w - 1 f$ ~2 l3 c/ O
- sw = Switch()2 N9 g5 s' Q- _2 `. g7 `( ]* z
- sw.value() # returns True or False4 o1 E: D& A& U- W+ Z3 K) L
- sw.callback(lambda: pyb.LED(1).toggle())
复制代码 6 l m0 r9 Y6 R" L% |- ]
H9 b g8 E4 r, B8 E/ K/ b7 {' Q
引脚和 GPIO请参阅 pyb.Pin. - from pyb import Pin
* O- V0 N0 Y, c& Y. g# P - # n; Z! ^- |' j4 C2 Y
- p_out = Pin('X1', Pin.OUT_PP)
. L& C; ~% \! D - p_out.high()( q* j* r1 m4 F& l3 d6 Z
- p_out.low()4 e) V0 c- H2 t+ T
- Z% R0 Z7 k9 l- p_in = Pin('X2', Pin.IN, Pin.PULL_UP); u! Z. H: z# X5 R( y7 {! ~% c
- p_in.value() # get value, 0 or 1
复制代码
5 G- {/ n4 W4 q6 E. W6 q
( Y ]: f% T9 s- F) d& Q伺服控制请参阅pyb.Servo. - from pyb import Servo6 ]1 w3 H! w) Y
( L/ n4 J0 f/ W- s1 = Servo(1) # servo on position 1 (X1, VIN, GND), k- U3 O+ v8 y. m. h- @. X5 S
- s1.angle(45) # move to 45 degrees6 [# Q$ G" T7 g. g7 X8 L
- s1.angle(-60, 1500) # move to -60 degrees in 1500ms, U; q2 H* q0 q7 C1 `
- s1.speed(50) # for continuous rotation servos
复制代码
8 y% `3 n3 f) B$ Z3 B: v4 G: K5 }0 f5 g& U! r8 N/ {2 h& I
外部中断请参阅 pyb.ExtInt. - from pyb import Pin, ExtInt9 x$ `5 \+ E0 Q" y" @
$ D) S5 y# o* Y* Q" V9 h- callback = lambda e: print("intr")) p& z3 H2 k7 e* \5 o* Y
- ext = ExtInt(Pin('Y1'), ExtInt.IRQ_RISING, Pin.PULL_NONE, callback)
复制代码 h8 O% }# @2 G! _; C2 ~
( L! Y5 r* k5 v% I1 q, |
计时器请参阅pyb.Timer. - from pyb import Timer, V/ H- ~/ _' d6 R
- C5 U V6 j! Q' Y7 ?$ |* d& `! @
- tim = Timer(1, freq=1000)& I6 Z% n1 B# E2 {8 {
- tim.counter() # get counter value; O( t; l2 t, J8 [$ _9 \7 W5 l
- tim.freq(0.5) # 0.5 Hz
9 a. D4 w% G) o* o - tim.callback(lambda t: pyb.LED(1).toggle())
复制代码 8 h6 u( n9 R) Z; n. l, }; z+ s
RTC(实时时钟)请参阅 pyb.RTC - from pyb import RTC7 h; b9 H3 Y8 G: n2 E
- 4 ]: l: y3 e% J( S
- rtc = RTC()
2 z+ D; B' E* w0 `, \ - rtc.datetime((2017, 8, 23, 1, 12, 48, 0, 0)) # set a specific date and time
8 S5 E- C2 d* L# e6 l+ D2 H8 X4 |8 t( k - rtc.datetime() # get date and time
复制代码 ! Y" r& e, }, B! G( F
PWM(脉宽调制)请参阅pyb.Pin 和 pyb.Timer. - from pyb import Pin, Timer9 i+ n4 p1 |8 ~) T1 U( j4 e2 J0 m
- % v; a7 t3 o! [$ _+ m( ?" h) ^
- p = Pin('X1') # X1 has TIM2, CH1
/ j' y6 n0 T/ F6 K' `8 ^1 s" t! Z - tim = Timer(2, freq=1000)
' L/ A; `3 ?, f' @: g$ E - ch = tim.channel(1, Timer.PWM, pin=p)
+ P* L" R) S5 P" G3 A0 y - ch.pulse_width_percent(50)
复制代码 ) x3 |+ b/ l1 z) a& \
ADC(模数转换)请参阅pyb.Pin 和pyb.ADC. - from pyb import Pin, ADC( I0 m- K/ A! B, d( ~7 Y k
z! l8 G' F* P3 v- adc = ADC(Pin('X19'))! m- a/ Z7 Y( N8 ~5 V9 w( o, g
- adc.read() # read value, 0-4095
复制代码 . x/ u7 a6 J+ \0 r1 \# u8 V% k6 C
1 m) k3 F' G' u9 t! w' p+ eDAC(数模转换)请参阅pyb.Pin 和 pyb.DAC. - from pyb import Pin, DAC9 m# ^7 b# a: l J' \0 S
) ~ C* x/ r: Y4 V$ g2 ~- dac = DAC(Pin('X5'))
5 c; N& `( j c/ T$ }1 \/ D4 c - dac.write(120) # output between 0 and 255
复制代码
7 ]% l& W. H, W5 D) O+ S6 Z+ h) P [# t
UART(串行总线)请参阅 pyb.UART. - from pyb import UART. _% v$ D6 ^( ] G6 O6 y2 ~
- # \6 Y* J/ m' m5 c. ?0 \' D: b+ v
- uart = UART(1, 9600)
9 V& J$ E' f- L& X8 p' o - uart.write('hello')
1 P6 i/ F7 C% T. } - uart.read(5) # read up to 5 bytes
复制代码 - d6 f `0 j2 C
$ q+ z2 \/ Q A9 a/ c
SPI总线请参阅 pyb.SPI. - from pyb import SPI1 R- H4 k5 B& l: A T/ H
9 C S p0 S$ l- F9 r7 x4 S- spi = SPI(1, SPI.MASTER, baudrate=200000, polarity=1, phase=0)7 |# n- ]5 Z6 M. ~1 u
- spi.send('hello')" p5 i4 } b8 j7 ]
- spi.recv(5) # receive 5 bytes on the bus
" _: N0 w% Z* w. D3 e - spi.send_recv('hello') # send and receive 5 bytes
复制代码 ) b* L, ~8 n, }+ N' _
1 g8 d) V" \4 d5 @, u/ ~0 O! i
I2C总线硬件 I2C 可通过I2C('X') 和用于 pyboard 的 X 和 Y 两半 I2C('Y')。或者,传入外围设备的整数标识符,例如I2C(1)。通过显式指定 scl 和 sda 引脚而不是总线名称,也可以使用软件 I2C 。有关更多详细信息,请参阅 machine.I2C. - from machine import I2C
' S* y, V! P- V) P# K; T$ [
3 u: E5 y0 r1 v" T" U& X O8 f, \- i2c = I2C('X', freq=400000) # create hardware I2c object/ R" z5 ] N" I# L
- i2c = I2C(scl='X1', sda='X2', freq=100000) # create software I2C object
- Q" S9 ? D8 s- D# ]( U! J$ S- |4 k! d - 1 m6 ^% ^# z/ g
- i2c.scan() # returns list of slave addresses P( U3 @. L1 {3 L; ~9 c! x
- i2c.writeto(0x42, 'hello') # write 5 bytes to slave with address 0x42) r8 b( ~6 A5 a) V
- i2c.readfrom(0x42, 5) # read 5 bytes from slave; _4 q! I) h8 a/ h2 i& `* J( ?$ S
- 4 {0 v. T" l; G6 C; G
- i2c.readfrom_mem(0x42, 0x10, 2) # read 2 bytes from slave 0x42, slave memory 0x104 {: @2 g8 v2 c: L8 V
- i2c.writeto_mem(0x42, 0x10, 'xy') # write 2 bytes to slave 0x42, slave memory 0x10
复制代码 ( z( n e: B% F/ k5 r/ L$ ?
; \0 [% A+ Y& y* E* P7 Z注意:对于传统 I2C 支持,请参阅 pyb.I2C。
* ?, B, K* y( {! ~! N7 I8 ~) J/ @I2S总线参见 machine.I2S. - from machine import I2S, Pin
' _+ J8 V( n: @% Q - 0 a1 M$ l) c: U( t1 y/ w
- 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* }8 k: V0 |; f& M' {
- i2s.write(buf) # write buffer of audio samples to I2S device6 M! {' M5 u" Q6 Y; ^. d7 A
- & u8 U7 D( C9 g7 R- t
- 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 M8 V* V& F: y% K
- i2s.readinto(buf) # fill buffer with audio samples from I2S device
复制代码 # ]+ U+ J; m9 n$ \0 I* u# [
I2S 类目前作为技术预览版提供。在预览期间,鼓励用户提供反馈。基于此反馈,I2S 类 API 和实现可能会更改。 PYBv1.0/v1.1 有一个 I2S 总线,id=2。PYBD-SFxW 有两条 I2S 总线,id=1 和 id=2。I2S 与 SPI 共享。 2 ~0 P" F6 b8 G J {2 B+ X
CAN总线(控制器局域网)参见 pyb.CAN. - from pyb import CAN/ f! M7 H$ n! K7 _' A( p
8 L% \$ y+ v: ~* Y3 |1 p- can = CAN(1, CAN.LOOPBACK)
2 o% N( }! \ u - can.setfilter(0, CAN.LIST16, 0, (123, 124, 125, 126))
" A" r0 k& o# { - can.send('message!', 123) # send a message with id 123* t7 ~$ N/ z0 B, z( ~! n& o
- can.recv(0) # receive message on FIFO 0
复制代码
$ o& F: T& Q/ N- R2 ?. h$ L0 \1 Q8 `( s1 N9 q5 t
内部加速度计参见pyb.Accel. - from pyb import Accel e5 S7 f) ? c% P. t4 r4 |# V/ `
" d- F Z! h, a- accel = Accel()' H* [7 m/ P8 X7 F$ J* {+ P6 E
- print(accel.x(), accel.y(), accel.z(), accel.tilt())
复制代码 & M; O' `' M4 \& x0 s* I+ G( z
/ q6 \% h4 g! x, C3 m
|