目录
- 1. 功能1:修改文件参数值
- 1.1. 获取网页端传参
- 1.2. 读取文件
- 1.2.1. 一般文件读取方式
- 1.2.2. 特殊文件 —— mlx文件
- 1.2.3. 特殊文件 —— .xlx文件
- 1.3. 查找数据修改位置,替换数据
- 2. 功能2:读取结果数据
- 2.1. 实时数据展示如何存储相关数据?
- 2.2. 读取相关数据,整理、打包、传递
- 2.2.1. 读取.mat文件
- 2.2.2. 读取.xlsx文件
- 2.2.3. 读取.txt/.log文件
- 3. 功能3:运行liunx命令行
- 3.1. 远程连接服务器
- 3.2. 执行liunx命令
- 3.3. 多线程执行
- 3.4. 实时读取liunx命令的输出数据
- 3.5. 随时终止liunx命令的执行
- 4. 其他收获
- 4.1. 异常处理
- 4.2 日志生成
- 4.3 环境部署
- 4.4. vscode远程连接服务器
- 5. 项目感受
- 6. 后记
前情回顾
Flask后端开发(一)-基础知识和前期准备
1. 功能1:修改文件参数值
针对文件参数值的修改,具体流程如下:
- 前端接收用户修改的数据,传递给后端;
- 后端接口接收数据之后,读取对应文件;
- 定位修改位置,替换数据;
- 返回修改结果给前端。
1.1. 获取网页端传参
前端传递参数的方式有两种,一种是GET,一种是POST,具体可参考Flask后端开发(一)-基础知识和前期准备
后端接收数据主要使用flask中的request
模块,具体代码如下:
#包导入
from flask import request#前后端协商好传递数据的名称之后,后端根据参数名进行接收
if request.method == "POST":userID= str(request.form.get("userID"))
elif request.method == "GET":userID= str(request.args.get("userID"))#如果需要额外处理,例如字符串"a,b,c"需要转换为列表["a","b","c"],可以使用split函数
BSD= (request.form.get("BSD")).split(",")#注:上述是代码片段,而非完整代码,一般后端接收数据写在接口函数中
1.2. 读取文件
1.2.1. 一般文件读取方式
一般文件包括.txt
、.c
、.log
等文件,其内容读取主要使用python中file
模块的open
函数,具体代码如下:
path= "文件路径"
with open(path, "r",encoding='utf8') as file:file_content = file.read()
#整个文件内容存储在file_content中
关于file
模块的具体使用,可参考我的这篇博客:【python技巧】文本文件的读写操作。
1.2.2. 特殊文件 —— mlx文件
本项目的一个特殊之处就是需要处理.mlx
文件(实时脚本文件),这是matlab中的一种文件格式,其内容是二进制的,无法直接读取。因此,在本文当中,解决方案是将.mlx
文件手动转换为.m
文件,然后再读取.m
文件的内容(真的很笨蛋,但是有效)。
对于.m文件,则可以按照一般文件的读取方式进行读取。
1.2.3. 特殊文件 —— .xlx文件
本项目中还会涉及到表格文件的数据读写,这里使用的是xlrd
模块,具体代码如下:
#包导入
import xlrd#查找对应文件内容
file_path="文件路径"
#打开表格
wb = xlrd.open_workbook(file_path)
ws = wb.sheet_by_name('Sheet1')
#按行读取,返回给前端一个行列表:
n_rows = ws.nrows#获取行数
for i in range(2,n_rows):#按行读取,进行筛选,第一行是表头,第二行开始是数据get_value=ws.cell(i,3).value#获取第i行第3列的数据
1.3. 查找数据修改位置,替换数据
本项目的需求是修改文件中的对应参数,涉及很多代码行的参数修改,因此,需要根据变量名查找相关位置。
- 定位
根据pytho字符串中的find函数
查找变量名所在的位置,参考博客如下Python find()方法,具体代码如下:
# 其中file_content是文件内容,变量名是需要查找的变量名
## 1. 调度类型start_index_1 = file_content.find("simParameters.SchedulingType =")end_index_1 = file_content.find("simParameters.NumUEs =",start_index_1,) # 这之间修改schedulingtype的取值## 2. UESpeedstart_index_2 = file_content.find("simParameters.UESpeed =", end_index_1)end_index_2 = file_content.find("% Validate the UE positions",start_index_2,)## 3. max_RBstart_index_3 = file_content.find("simParameters.NumRBs =", end_index_2)end_index_3 = file_content.find("simParameters.SCS =",start_index_3,) ## 4. SCSstart_index_4 = file_content.find("simParameters.SCS =", end_index_3)end_index_4 = file_content.find("simParameters.DLCarrierFreq =",start_index_4,)
这部分的下标定位情况,可参考我的此篇博客:【python技巧】替换文件中的某几行
- 替换
在本项目中使用的全文替换,具体代码结构如下:
# 1. 读取文件
path = "文件路径"
with open(path, "r",encoding='utf-8') as file:
file_content = file.read()# 2. 定位
start_index_1 = file_content.find("simParameters.UEPosition =")
end_index_1 = file_content.find("simParameters.UESpeed =",start_index_1) # 这之间修改ue_position的取值
start_index_2 = file_content.find("simParameters.Position = ", end_index_1)
end_index_2 = file_content.find("csirsConfig = nrCSIRSConfig", start_index_2)if (start_index_1 == -1 or end_index_1 ==