我分析试飞信号,原始信号是几十赫兹频率采样的时间信号,你们这个里面没有时间类型的变量,导致没法代入进行计算呀。你看竟品时间都能当横轴画图。加减乘除也没啥问题。
我试着用软件做我在商飞日常工作:导入试飞数据(时间序列数据,空格分隔,列对齐的文本文档)结果不支持txt后缀,改成csv之后果然导入有些问题。另外,你们导入.mat文件不支持比较新的table变量,这个变量格式我认为比矩阵,向量都要更有生命力。因为以上两个原因,我没能导入试飞数据进行计算尝试。这种导入数据的开发工作只是外围的琐碎开发工作,但对于使用体验影响还是蛮大的。
在使用北太天元编写一个程序时,经常需要从外部读入数据,或者将程序运行的结果保存为文件,北太天元主要支持以下格式数据文件的导入导出:.mat、.txt、.csv、.xls、.xlsx。具体介绍及用法如下。一、MAT文件的导入导出1. MAT文件的导出1.1 使用save函数
>> help save save 将工作区变量保存到文件中。 save(filename),将当前工作区中的所有变量存储在名为 filename 的二进制文件 MAT 文件中。 filename 为字符向量或字符串标量。例如,将文件名指定为 "myFile" 或 "myFile.mat"。 如果未指定文件名,则将数据保存到名为 baltamatica.mat 的文件中。 如果 filename 不包含扩展名,则会默认补充 '.mat' 扩展名。如果文件名不包含完整路径,则保存在当前文件夹中。 保存路径必须具有写入文件的权限。 当第一个参数为 '-struct' 时,会将 '-struct' 后的第二个参数 (非以 '-' 开头的参数) 当做 filename, 如 save('-struct',structname,filename,fieldnames)。 save(filename,variables),仅存储指定的变量。filename 和 variables 为字符向量或字符串标量。 variables 可使用 '*' 通配符匹配模式。例如,save('data.mat','A*') 保存以 A 开头的所有变量。 save(filename,'-struct',structname,fieldnames),将标量结构体的字段存储为单个变量。 如果使用了 fieldnames 参数,则 save 函数仅存储结构体中的 fieldnames 字段。 fieldnames 与 variables 具有相同的形式。不能在同一调用中指定 variables 和 '-struct' 来保存数据。示例:保存structure数组实例。例如有如下的structure数组s1:s1.a = 22.33; s1.b =”Steve”; s1.c = ' World!';使用 save 命令,可将整个structure数组保存为struct_data.mat。
>> save('struct_data.mat', 's1');1.2 使用界面操作在工作区中使用鼠标左键选中要保存的数据,点击鼠标右键,会弹出操作框,点击保存即可,在工作区空白处点击鼠标右键,可保存工作区的所有变量。2.MAT文件的导入2.1使用load函数
>> help load load 将文件变量加载到工作区中。 load(filename),将 MAT 文件中的变量加载到工作区。 filename 为字符向量或字符串标量。例如,将文件名指定为 "myFile" 或 "myFile.mat"。 如果未指定文件名,默认读取当前路径下的 baltamatica.mat。 load(filename,variables),读取指定的变量。filename 和 variables 为字符向量或字符串标量。 variables 可使用 '*' 通配符匹配模式。例如,load('data.mat','A*') 加载以 A 开头的所有变量。 load(filename,'-mat') 将 filename 视为 mat 文件,而不管文件扩展名如何。 load(filename,'-mat',variables) 加载 filename 文件中的指定变量。示例:将A.mat文件中的变量导入到structure数组s中。
>> s=load("A.mat") s = 1x1 struct 结构体: A1: [3x3 double] A2: "string" A3: [1x3 double] A4: [1x2 cell array]2.2 使用界面操作点击菜单栏的“导入“->”导入数据”弹出导入文件操作界面二、TXT、CSV及Excel文件的导入导出1. TXT、CSV及Excel文件的导入1.1 使用readmatrix函数(1)导入文本文件文本文件的数据格式在行和列上必须采取一致的模式,并使用分隔符来分隔各个数据项。分隔符可以是空格、逗号、分号或其他字符,单个的数据可以是字母、数值字符或它们的混合形式。示例:文件data.txt包含了两行数据,各数据之间由空格分隔。1 2 34 5 6
>> m=readmatrix("data.txt") %使用readmatrix导入数据 m = 2x3 double 1 2 3 4 5 6(2)导入csv数据csv文件是逗号分隔的纯文件文件。除了可以使用readmatrix函数读取之外,同时也可以使用csvread函数,推荐使用readmatrix函数。示例:文件data.csv中的数据如下:1.2,2.5,3.2,4.65.4,6.2,7.1,8.2
>> m=readmatrix("data.csv") %使用readmatrix导入数据 m = 2x4 double 1.2000 2.5000 3.2000 4.6000 5.4000 6.2000 7.1000 8.2000(3)导入Excel数据Excel文件包含.xls及.xlsx两类文件。示例:文件data.xlsx中的数据如下:
>> m=readmatrix("data.xlsx") %使用readmatrix导入数据 m = 5x2 double 1.0000 2.0000 3.0000 4.0000 5.0000 6.0000 NaN NaN 7.0000 8.00001.2 使用界面操作点击菜单栏的“导入“->”导入数据”,弹出导入文件操作界面,选择文件导入即可。2. TXT、CSV及Excel文件的导出2.1使用writematrix函数(1)保存txt文本文件示例:将a=[1,2,3;4,5,6;7,8,9]'所表示的矩阵数据存储到“w_data.txt”的文件当中,以制表符分隔。
>> a = 3x3 double 1 4 7 2 5 8 3 6 9 >> writematrix(a,"w_data.txt","Delimiter","-")使用文本查看器查看w_data.txt:(2)保存csv文本文件示例:将a=[1,2,3;4,5,6;7,8,9]'所表示的矩阵数据存储到“w_data.csv”的文件当中。
>> writematrix(a,"w_data.csv")使用wps查看器查看w_data.csv:(3)保存xlsx文本文件
>> writematrix(a,"w_data.xlsx")使用wps查看器查看w_data.xlsx:注:暂不支持.xls文件格式的导出操作,excel推荐使用.xlsx的导出文件格式。2.2 使用界面操作在工作区中使用鼠标左键选中要保存的数据,点击鼠标右键,会弹出操作框,点击“导出变量”即可。该方式仅支持”.xlsx”格式文件的导出。