联调 matlab 遇到的一些事儿

记录当时遇到的问题,因为平时不写 matlab,所以没有深入的理解。

版本兼容

当时遇到的第一个问题就是不同版本 matlab 带来的兼容性问题。同时开发使用的是 2021a 版本,而调试时使用的是 2022b 版本。在新版本中某些函数已被弃用,导致程序运行失败。

因此,在一个团队内部,应该使用统一的 matlab 版本,同时要在程序中严格声明适用的版本。

可以尝试通过以下方式,检查兼容性,提升兼容性:

  1. codeCompatibilityReport 代码兼容性报告)通过这个函数可以查看项目代码的兼容性。
  2. MATLAB 代码兼容性分析器
  3. 升级工程

网络操作

websave、webwrite、webread

通过 RESTFul API 读写数据。也可以适用 webread get 网络数据

websave 可以通过 get 方法获取数据,并存储到指定的文件中。

matlab 复制代码
% http 客户端
% 需要注意的是,resulttemp 不用转为字符串,工具自己会根据 Content-Type 自动处理传入的 data 数据

import matlab.net.http.*
import matlab.net.http.field.*

resulttemp = containers.Map();
resulttemp("topic") = topic;
resulttemp("key") = key;
resulttemp("msg") = msg;

uri = matlab.net.URI("http://10.3.63.38:9100/mq/");
headers = HeaderField("Content-Type","application/json");
req = RequestMessage(RequestMethod.POST, headers, resulttemp);
req.send(uri);
matlab 复制代码
% 适用 form-data 上传文件。
% matlab 提供了其他不同的 Provider 满足业务需求,可以自行探索
fps = matlab.net.http.io.FileProvider("aa.zip");
formProvider = matlab.net.http.io.MultipartFormProvider("ext", "zip", "file",fps);
req = matlab.net.http.RequestMessage('post',[],formProvider);
uri = matlab.net.URI('http://10.3.63.38:9004/stash/upload');
result = req.send(uri);  

写文件

matlab 复制代码
% 通用函数,可以将字节,字符串等数据直接写入到文件
x = 0:.1:1;
A = [x; exp(x)];

fileID = fopen('exp.txt','w');
fprintf(fileID,'%6s %12s\n','x','exp(x)');
fprintf(fileID,'%6.2f %12.8f\n',A);
fclose(fileID);

writetablewritematrixwritecell 可以将对应数据类型的数据写入文件,文件格式支持 .txt、.dat、csv、.xls 等。详见官方文档。

xlswrite 在高版本中已经弃用,在项目中不建议适用。

相关推荐
wn5318 分钟前
【Go - 类型断言】
服务器·开发语言·后端·golang
Hello-Mr.Wang20 分钟前
vue3中开发引导页的方法
开发语言·前端·javascript
救救孩子把23 分钟前
Java基础之IO流
java·开发语言
WG_1724 分钟前
C++多态
开发语言·c++·面试
宇卿.31 分钟前
Java键盘输入语句
java·开发语言
Amo Xiang41 分钟前
2024 Python3.10 系统入门+进阶(十五):文件及目录操作
开发语言·python
friklogff1 小时前
【C#生态园】提升C#开发效率:深入了解自然语言处理库与工具
开发语言·c#·区块链
重生之我在20年代敲代码2 小时前
strncpy函数的使用和模拟实现
c语言·开发语言·c++·经验分享·笔记
爱上语文2 小时前
Springboot的三层架构
java·开发语言·spring boot·后端·spring
编程零零七4 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql