以下是开发板上手之后的硬件准备步骤
Step1:硬件准备
开始之前需要准备以下配件
Step2:天线&SIM卡安装
安装开发板配套的天线,安装位置为LTE天线座位置,并将SIM卡插入开发板上的SIM卡座。
使用 USB Type-C 数据线连接开发板的 Type-C 和电脑 USB 口即可完成供电。
开发板上USB和DC的电源选择开关拨到USB处
长按PWRKEY开机,在按下PWRKEY按键之前,需保证供电电压稳定。建议从上电到按下PWRKEY按键之间的时间间隔不少于30 ms。开机后开发板NET灯闪烁,开发板已正?。
选择与模组型号匹配的驱动,该开发板搭载的模组有EC800M,以EC800M为例,在下载页面右侧选择该型号的USB驱动QuecPython_USB_Driver_Win10_ASR点击下载,如果开发板搭载的是其他型号同样按照以上操作即可。
下载后解压驱动压缩包,找到"setup.exe"?或者是"setup.bat",双击运行即可,安装完之后打开设备管理器就可以看到设备管理器中端口的黄色感叹号消失了,说明安装成功,能够正常通信。
出现?Mobile ECM Network Adapter?或?CDC Ethernet Control Modle (ECM)?等设备未被识别属于正常现象,不影响固件烧录和后续开发,无需理会。
使用QuecPython进行开发需要用到专用的开发调试工具——QPYcom,包括但不限于调试代码、分析日志、文件传输、烧录固件、合并固件等。
打开QuecPython工具下载页面,根据操作系统选择对应的工具进行下载。
注意:该工具无需安装,解压即用。
编辑Python代码一般会用到专用于Python或者兼容多种语言的IDE,可以有效提升开发效率,这里推荐VSCode
针对VScode,QuecPython推出专用插件实现代码提示、代码补全和串口调试等功能,安装方法见下图
在VSCode中点击侧边栏插件市。诓寮市场中搜索 “QuecPython”,根据搜索结果下载该插件即可

固件获取
模组在出厂时通常烧录有标准 AT 固件或 QuecOpen 固件,如需基于 QuecPython 对模块进行开发,需要手动为其重新烧录专门的 QuecPython 固件。

面对官网种类众多的固件,如何选择合适的固件包,首先需要知道使用的模组的型号,模组型号可以通过模组的镭雕或者发送AT指令来获得。
在获取到模组型号之后根据模组的型号去官网下载该模组对应的固件即可,固件的名称一般为QPY_OCPU_版本号_模组型号_FW,没有特殊需求默认下载最新版本即可。
点击下载列的下载按钮即可下载,下载成功后会得到一个固件名称命名的压缩包文件(zip包)
从官网下载的固件包为压缩包格式,固件压缩包下载到本地后,需进行解压。解压后可获得两个文件,其中 .bin 格式的是 QuecPython 固件本体,.md 格式的是更新日志。

请务必将压缩包内容解压至一个不包含中文、空格和其他特殊字符的路径下,否则下载工具可能无法正常识别到固件,同时下载工具路径也不可包含中文、空格和其他特殊字符。
固件烧录
首先确保模组连接正常并已开机,打开QPYcom工具进入下载页面,点击"创建"项目,新建要下载的固件项目,项目名称自定义,配置完成后持久化保存
选择要下载到模组的固件(根据要下载的模组型号选择对应的固件,若为新格式固件则所有模组型号都选择.bin文件即可)
如果是老版本固件,固件文件格式不一定以bin结尾,其中EC600U系列模组选择解压后的pac文件
单击“Download script”右侧的下拉选择箭头,选择"Download FW"
点击"Download FW"后,开始下载固件,下载过程会有进度条和进度百分比显示,等待下载完毕会有弹窗提示下载成功

REPL全称为Read-Eval-Print-Loop (交互式解释器),可以在REPL中进行QuecPython程序的调试
运行?QPYcom?工具后,选择正确的串口(波特率无需指定)并打开,即可开始 Python 命令行交互。
打开QPYcom工具,端口选择连接Quectel USB REPL Port,选择“交互”界面
点击“打开串口”按钮,在交互界面输入print(‘hello world’),按回车后可以看到执行的结果信息

注意:工具交互页面输入时需要输入英文字符,中文字符将会被屏蔽
创建helloworld.py文件输出“hello world”,打印“hello world”,编写脚本如下所示:
通过QPYcom将上面编辑好的文件下载到模组中去并运行

下载方法一:

首先选择模组的交互口,点击"打开串口"按钮
可以通过文件页面右侧上面的 "+","-" 按钮来上传和删除文件
也可以通过拖拽的方式将文件页面左侧显示的本地文件直接拖拽到右侧模组中去(也可以拖拽文件夹)
下载过程中会在状态栏显示下载文件名和下载进度
下载方法二:

根据需求,创建用户项目(点击"创建"按钮),步骤同上文烧录固件
选择需要下载到?榈挠没Ы疟(在"用户脚本"区域通过右键菜单添加)
左击下拉选择箭头,选择"下载脚本",即"Download Script"
点击"下载脚本"开始下载脚本,下载过程中有进度条提示
将要执行的脚本文件下载到模组中去,具体步骤参考上文
打开串口之后,在QPYcom交互页面输入以下代码执行脚本文件
或者通过QPYcom文件页面?执行?按钮执行脚本文件,在工具的文件页面选择要执行的脚本文件然后点击 "?"按钮
执行结果如图

如何停止正在运行的程序,根据运行的脚本文件类型有以下方法:
| 程序名是否 为main.py |
程序中是否 包含了死循环 |
程序中是否 使用了多线程 |
停止步骤 |
|---|---|---|---|
| ? | ? | ? | (1)按 Ctrl + A 键进入 RAW 模式 (2)按 Ctrl + D 键重启 QuecPython 虚拟机 (3)按 Ctrl + B 键回到普通交互模式 (4)若以上方法无效,请重新烧录固件 |
| ? | (1)按 Ctrl + C 键打断程序运行 (2)若以上方法无效,请重新烧录固件 |
||
| ? | ? | (1)按 Ctrl + A 键进入 RAW 模式 (2)按 Ctrl + D 键重启 QuecPython 虚拟机 (3)按 Ctrl + B 键回到普通交互模式 (4)若以上方法无效,请耐心等待程序运行结束 |
|
| ? | (1)按 Ctrl + C 键打断程序运行 (2)若以上方法无效,请重新烧录固件 |
||
| ? | ? | ? | (1)按 Ctrl + D 键重启 QuecPython 虚拟机 (2)若以上方法无效,请直接重启? |
| ? | (1)按 Ctrl + D 键重启 QuecPython 虚拟机 (2)若以上方法无效,请直接重启? |
||
| ? | ? | (1)按 Ctrl + C 键打断程序运行 (2)若以上方法无效,请重新烧录固件或直接重启模块 |
|
| ? | (1)按 Ctrl + C 键打断程序运行 (2)若以上方法无效,请重新烧录固件或直接重启? |


引脚接口资源表
| 引脚编号 | ?橐琶 | GPIO 标识 | 功能描述 | 接口类型 | 电平 / 属性 |
| 1 | P41 | GPIO14 | I2C1 数据信号 | I2C 接口 | 3.3V GPIO |
| 2 | P40 | GPIO13 | I2C1 时钟信号 | I2C 接口 | 3.3V GPIO |
| 3 | P65 | Reserved | 保留引脚 | Reserved | - |
| 4 | P64 | GPIO15 | SPI0 MOSI(主发从收) | SPI 接口 | 3.3V GPIO |
| 5 | P88 | GPIO21 | SPI0 MISO(主收从发) | SPI 接口 | 3.3V GPIO |
| 6 | P25 | GPIO9 | SPI0 片选信号 | SPI 接口 | 3.3V GPIO |
| 7 | P26 | GPIO10 | SPI0 时钟信号 | SPI 接口 | 3.3V GPIO |
| 8 | P28 | GPIO12 | UART1 接收引脚 | UART 接口 | 3.3V UART |
| 9 | P27 | GPIO11 | UART1 发送引脚 | UART 接口 | 3.3V UART |
| 10 | P26 | LT_EN | LTE 模块使能控制 | 控制信号 | 3.3V 控制 |
| 11 | - | 1V8 | 1.8V 电源输出 | 电源轨 | 1.8V 电源 |
| 12 | - | PON | 电源管理控制信号 | 电源管理信号 | 3.3V 控制 |
| 13 | - | GND | 接地引脚 | 地 | GND |
| 14 | - | CHRG | 充电状态指示信号 | 状态指示信号 | 3.3V 状态 |
| 15 | - | SPK_N | 扬声器负端输出 | 音频接口 | 音频驱动 |
| 16 | - | SPK_P | 扬声器正端输出 | 音频接口 | 音频驱动 |
| 17 | - | MIC_N | 麦克风负端输入 | 音频接口 | 音频输入 |
| 18 | - | MIC_P | 麦克风正端输入 | 音频接口 | 音频输入 |
| 19 | - | PA | 功率放大控制信号 | 状态指示信号 | 3.3V 控制 |
| 20 | P18 | GPIO5 | UART4 接收引脚 | UART 接口 | 3.3V UART |
| 21 | P19 | GPIO6 | UART4 发送引脚 | UART 接口 | 3.3V UART |
| 22 | P22 | - | DBG_RXD(调试串口接收) | UART 接口 | 3.3V UART |
| 23 | P23 | - | DBG_TXD(调试串口发送) | UART 接口 | 3.3V UART |
| 24 | - | LEVEL_LINE | 电平检测 / 线路状态信号 | 状态指示信号 | 3.3V 状态 |
| 25 | - | GND | 接地引脚 | 地 | GND |
| 26 | - | PWR | 电源使能 / 电源轨 | 电源轨 | 电源控制 |
| 27 | - | VDD | 核心电源输入 | 电源轨 | 电源输入 |
| 28 | P85 | GPIO16 | PWM0 输出引脚 | PWM/GPIO | 3.3V PWM |
| 29 | - | GPIO18 | 通用输入输出引脚 | GPIO | 3.3V GPIO |
| 30 | P39 | GPIO25 | RI(振铃指示)信号 | 状态指示信号 | 3.3V 状态 |
| 31 | P30 | GPIO20 | DTR(数据终端就绪)信号 | 状态指示信号 | 3.3V 状态 |
| 32 | P35 | - | UART2_TXD(主串口发送) | UART 接口 | 3.3V UART |
| 33 | P34 | - | UART2_RXD(主串口接收) | UART 接口 | 3.3V UART |
| 34 | - | GND | 接地引脚 | 地 | GND |
| 35 | - | VIN | 外部电源输入 | 电源轨 | 电源输入 |
| 36 | - | EN | ?槭鼓 / 复位控制 | 控制信号 | 3.3V 控制 |
| 37 | - | GND | 接地引脚 | 地 | GND |
| 38 | - | BAT | 电池供电输入 | 电源轨 | 电池输入 |