我尝试了很多不同的第三方micropython工具,有些是Windows应用程序,有些是VScode插件。
但是当我尝试过MicroPython的mpremote工具后,我几乎决定它将成为我的首选工具。?
我通常将其与VScode结合使用。它的代码突出显示,自动完成和自动缩进非常有用。同时打开其他插件也很容易。另外VScode也是一个多平台的IDE,我比较习惯在几个不同的操作系统里用同一个IDE,来回切换不会生手。
也许有些极简主义者,我认为mpremote工具也会很合适,只需将系统的终端与任何文本编辑器一起使用即可,如果你是命令行老手,则只需要一个终端即可完成所有操作。
目录 (Table of Contents)
PyPI 页面 在终端用pip install mpremote命令即可安装。(推荐)
本文在GitHub micropython/discussions/9096的页面
这可能是除 repl 之外最常见的命令,用于将文件从本地复制到设备,或从设备复制到本地。可能是因为我还不熟悉终端命令语法,起初我无法从MicroPython文档中的几个用例中完全掌握cp命令的用法,反复运用和尝试后就渐渐上手了。
首先创建一个干净的临时文件夹,并在其中写入一个main.py文件。
print ("start")
for i in range(2):
print(i)
print ("end")
最简单的用例,在终端中输入此文件夹路径,将文件从本地复制到设备:
mpremote connect COM1 cp main.py :
mpremote connect COM1 cp main.py :main.py
这两个命令实现完全相同的功能。
在:符号之后,如果输入文件名,则文件在复制到设备时将重命名为此文件名。
将文件从设备复制到本地 :
mpremote connect COM1 cp :main.py .
mpremote connect COM1 cp :main.py main.py
这两个命令实现完全相同的功能。
如果要重命名,可以删除.符号并输入所需的文件名。
它有点复杂。
在 Windows 上,使用文件的绝对路径从本地复制到设备:
mpremote connect COM1 cp D:\temp\main.py :main.py
将文件从设备复制到本地 :
mpremote connect COM1 cp :main.py D:\temp\main.py
目前在mpremote 0.3.0版本,应特别注意在Windows中不能省略目标文件名!
我在 GitHub 上已提交PR #9148 对 Windows 路径名分隔符的支持,下一个版本应该就可以随意在Windows里使用相对路径和绝对路径了,不影响其他功能。
在 Linux(如 Ubuntu)中,从绝对路径复制文件可以省略目标文件名:
mpremote connect /dev/ttyACM0 cp ~/temp/main.py :
mpremote connect /dev/ttyACM0 cp /home/wind/temp/main.py :
mpremote connect /dev/ttyACM0 cp :main.py ~/temp/
mpremote connect /dev/ttyACM0 cp :main.py /home/wind/temp/
在Linux中,例如Ubuntu,将多个文件从本地复制到具有绝对路径的设备:
mpremote connect /dev/ttyACM0 cp ~/temp/main.py ~/temp/main2.py :
将多个文件从设备复制到本地绝对路径:
mpremote connect /dev/ttyACM0 cp :main.py :main2.py ~/temp/
这些命令用于控制远程设备在不复制文件的情况下运行 Python 代码或脚本。
mpremote connect COM1 exec "print(1234)"
就像在REPL中输入一行Python代码一样。
mpremote connect COM1 run test_1.py
就像在REPL中进入粘贴模式一样,将代码复制并粘贴到指定的Python脚本中,然后运行它。
我未曾想过有这种使用MicroPython设备的方法,请看以下用例并尝试理解它,随后你就会像我一样对这个功能爱不释手~~
首先创建一个干净的临时目录,并在其中写入一些Python脚本,如下所示:
# numbers.py
num_1 = 21
num_2 = 22
num_3 = 23
num_4 = 24
# test_1.py
print("test_1 start")
import numbers
print(numbers.num_1)
print(numbers.num_2)
print(numbers.num_4)
print("test_1 end")
# test_2.py
print("test_2 start")
import numbers
temp1 = numbers.num_3 - numbers.num_2
print(temp1)
temp1 = numbers.num_3 - numbers.num_1
print(temp1)
print("test_2 end")
在终端中输入此目录的路径。
我们先确认一些信息,列出设备上的文件:
mpremote connect COM1 ls
ls :
139 boot.py
进入 REPL 并再次确认:
mpremote connect COM1 repl
>>> uos.listdir()
['boot.py']
>>>
退出 REPL,挂载本地目录,再次进入 repl:
mpremote connect COM1 mount . repl
再次确认文件:
>>> uos.listdir()
['numbers.py','test_1.py', 'test_2.py']
这里没有boot.py,但我们在本地目录创建的Python脚本出现在列表中。
导入并运行两个测试脚本:
>>> import test_1,test_2
test_1 start
21
22
24
test_1 end
test_2 start
1
2
test_2 end
>>>
查看一个文件:
>>> f=open("numbers.py")
>>> print(f.read())
# numbers.py
num_1 = 21
num_2 = 22
num_3 = 23
num_4 = 24
>>>
惊讶之余,你可能想知道,这些python脚本文件是不是全部都上传到设备上并存储起来了?我最初也是这么猜测的。
现在,我们将终端保留在REPL中,在本地修改此文件:
# numbers.py
num_1 = 1
num_2 = 12
num_3 = 23
num_4 = 35
返回 REPL 并再次检查:
>>> f=open("numbers.py")
>>> print(f.read())
# numbers.py
num_1 = 1
num_2 = 12
num_3 = 23
num_4 = 35
>>>
这样就解除疑惑了,文件只保存在本地目录中,并且这个目录被挂载在设备上。
软件重置后,并将重新挂载目录。
这就像是一个移动硬盘,或者是说像是NAS,云盘,连在MicroPython设备上,显然这个功能能极大节约设备的flash寿命,通常只需要在必须脱机运行的时候再把python脚本文件拷贝到flash里即可。
推荐使用以下组合命令执行python脚本:
mpremote connect COM1 mount . exec "import test_1"
在REPL中使用uos.listdir("/")命令你将看到原来存储在flash中的文件:
>>> uos.listdir("/")
['remote', 'boot.py', 'main.py']
如果你想保持挂载本地目录的状态下使用flash中的脚本(例如main.py),你可以使用如下命令将原flash根目录路径添加进sys.path列表中:
>>> import sys
>>> sys.path
['', '.frozen', '/lib']
>>> sys.path.append("/")
>>> sys.path
['', '.frozen', '/lib', '/']
>>> import main
如果挂载的本地目录中已有main.py,则仅会运行本地目录的main.py,可通过reverse()调换列表顺序:
>>> sys.path
['', '.frozen', '/lib', '/']
>>> sys.path.reverse()
>>> sys.path
['/', '/lib', '.frozen', '']
>>> import main
现在就会优先运行flash中的脚本。
如果我们需要对一个脚本一遍测试一遍修改,而脚本中已经导入了很多存储在本地的脚本模块,这样的情况下,每一次挂载测试都将花费数秒甚至数十秒的时间。
我总结了一种方法,在REPL中设法不重复的import模块即可有效减少运行时间。
以测试SSD1306 OLED显示屏为例,main.py是主程序,ssd1306.py是驱动模块,此处就不再完整列举程序代码了。
通过time.tick_ms()来验证测试本地目录的main.py脚本所需的时间,可见大概需要6秒:
>>> import time;t1 = time.ticks_ms();import main;time.ticks_diff(time.ticks_ms(),t1)
6032
使用sys.modules可以查看当前已经导入的脚本模块,可见ssd1306.py已经导入:
>>> import sys;sys.modules
{'main': <module 'main' from 'main.py'>, 'ssd1306': <module 'ssd1306' from 'ssd1306.py'>, 'flashbdev': <module 'flashbdev' from 'flashbdev.py'>}
我们仅需移除main而保留其他的模块:
>>> del main;sys.modules.pop('main')
<module 'main' from 'main.py'>
>>> import sys;sys.modules
{'ssd1306': <module 'ssd1306' from 'ssd1306.py'>, 'flashbdev': <module 'flashbdev' from 'flashbdev.py'>}
再次测试:
>>> import time;t1 = time.ticks_ms();import main;time.ticks_diff(time.ticks_ms(),t1)
1612
得到明显改善。
我正在使用RubyonRails3.0.9,我想生成一个传递一些自定义参数的link_toURL。也就是说,有一个articles_path(www.my_web_site_name.com/articles)我想生成如下内容:link_to'Samplelinktitle',...#HereIshouldimplementthecode#=>'http://www.my_web_site_name.com/articles?param1=value1¶m2=value2&...我如何编写link_to语句“alàRubyonRailsWay”以实现该目的?如果我想通过传递一些
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,
我想找到在某些文本中找到一些(让它是两个)句子的好方法。什么会更好-使用正则表达式或拆分方法?你的想法?应JeremyStein的要求-有一些例子示例:输入:ThefirstthingtodoistocreatetheCommentmodel.We’llcreatethisinthenormalway,butwithonesmalldifference.IfwewerejustcreatingcommentsforanArticlewe’dhaveanintegerfieldcalledarticle_idinthemodeltostoretheforeignkey,butinthis
我最喜欢的Google文档功能之一是它会在我工作时不断自动保存我的文档版本。这意味着即使我在进行关键更改之前忘记在某个点进行保存,也很有可能会自动创建一个保存点。至少,我可以将文档恢复到错误更改之前的状态,并从该点继续工作。对于在MacOS(或UNIX)上运行的Ruby编码器,是否有具有等效功能的工具?例如,一个工具会每隔几分钟自动将Gitcheckin我的本地存储库以获取我正在处理的文件。也许我有点偏执,但这点小保险可以让我在日常工作中安心。 最佳答案 虚拟机有些人可能讨厌我对此的回应,但我在编码时经常使用VIM,它具有自动保存功
我在我的rails应用程序中安装了来自github.com的acts_as_versioned插件,但有一段代码我不完全理解,我希望有人能帮我解决这个问题class_eval我知道block内的方法(或任何它是什么)被定义为类内的实例方法,但我在插件的任何地方都找不到定义为常量的CLASS_METHODS,而且我也不确定是什么here,并且有问题的代码从lib/acts_as_versioned.rb的第199行开始。如果有人愿意告诉我这里的内幕,我将不胜感激。谢谢-C 最佳答案 这是一个异端。http://en.wikipedia
我正在尝试上传文件。一个简单的hello.txt。我正在关注文档,但无法将其上传到我的存储桶。#STARTAWSCLIENTs3=Aws::S3::Resource.newbucket=s3.bucket(BUCKET_NAME)begins3.buckets[BUCKET_NAME].objects[KEY].write(:file=>FILE_NAME)puts"Uploadingfile#{FILE_NAME}tobucket#{BUCKET_NAME}."bucket.objects.eachdo|obj|puts"#{obj.key}=>#{obj.etag}"endresc
我正在使用ruby1.8.7。p=lambda{return10;}deflab(block)puts'before'putsblock.callputs'after'endlabp以上代码输出为before10after我将相同的代码重构到这里deflab(&block)puts'before'putsblock.callputs'after'endlab{return10;}现在我收到LocalJumpError:意外返回。对我来说,这两个代码都在做同样的事情。是的,在第一种情况下我传递了一个过程,在第二种情况下我传递了一个block。但是&block将该block转换为pro
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我最近开始学习Ruby,这是我的第一门编程语言。我对语法感到满意,并且我已经完成了许多只教授相同基础知识的教程。我已经写了一些小程序(包括我自己的数组排序方法,在有人告诉我谷歌“冒泡排序”之前我认为它非常聪明),但我觉得我需要尝试更大更难的东西来理解更多关于Ruby.关于如何执行此操作的任何想法?