MicroPython
学习python中无意发现了MicroPython。MicroPython是一款可以运行于微控制器的Python语言,除了继承了Python的语言特性以外,当然也继承了Python强大的功能库。
NodeMcu
NodeMcu 是基于esp8266的一款开源硬件,官方是使用lua语言开发,如今也支持MicroPython编程了,重新烧写MicroPython固件后便可以通过烧入py文件了
webserver
说完了软件和硬件,接下来进行第一个小例子吧,esp8266是一款优秀的wifi芯片,所以我们第一个项目便是通过webserver对板载led进行操作
首先说说原理吧,NodeMcu连上路由器后作为web服务器,通过其他设备连接同一个网络后访问服务器ip就可以打开操作led页面。接下来直接上代码吧
# 操控硬件的最主要的库,对io进行操作
from machine import Pin
import socket
import network
# 设置需要连接 的WiFi信息
wifiName="Grey"
wifiPassword="123456654321"
# 设置模块为STA模式 用作连接wifi
sta_if = network.WLAN(network.STA_IF)
sta_if.active(True)
sta_if.disconnect()
print("正在连接"+wifiName,end="")
# 开始连接
sta_if.connect(wifiName,wifiPassword)
i=0
while(sta_if.status()!=5):
print(".",end="")
time.sleep(1)
i=i+1
if i==13 :
break
if sta_if.isconnected() :
# 打印连接信息 获取本机IP 之后创建套接字需要用到
print("\n连接成功 本机ip为"+sta_if.ifconfig()[0])
p2.value(0)
else :
print("\n连接超时")
# 设置2号io口为输出(板载led连接在2号io口)
led=Pin(2, Pin.OUT)
# web请求后返回的网页代码
html= """<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>NodeMcu板载LED灯控制</title>
</head>
<body>
<h1>当前led灯状态:%s</h1>
<br><br>
<a href=\"/LED=ON\"\"><button>开灯</button></a>
<a href=\"/LED=OFF\"\"><button>关灯</button></a><br />
</body>
</html>
"""
# 创建套接字
addr = socket.getaddrinfo(sta_if.ifconfig()[0], 80)[0][-1]
s = socket.socket()
s.bind(addr)
s.listen(1)
print('listening on', addr)
# 循环监听get请求
while True:
cl, addr = s.accept()
print('client connected from', addr)
request = cl.recv(1024)
LedState=""
# 对request剪切出get请求内容 通过get请求对led灯进行操作
if request.decode()[:20].find("LED=ON") != -1:
# 对io2口输出低电平,led灯亮
led.value(0)
LedState="打开"
elif request.decode()[:20].find("LED=OFF") != -1:
# 对io2口输出高电平,led灯灭
led.value(1)
LedState="关闭"
# 对请求返回respone后关闭套接字
response = html % LedState
cl.send(response)
cl.close()
页面展示:
总结&扩展
以上通过简单的代码就实现了一个webserver。将python中难以捉摸的网络编程通过硬件得以具体的展示,同时对于硬件来说,使用python这种高级语言开发起来更加快捷方便,两者相得益彰。同时这个例子只是简单的webserver,在此之上可以有更多扩展,比如将io口控制继电器,而继电器后可以控制各种各样的电器,如果你家里有外网ip,将nodemcu的端口在路由器上映射后便可以实现外网访问。如此一来智能家居便可以轻易实现了。