将.csv文件调用到Octave

时间:2014-08-15 11:21:58

标签: csv octave

我有一个用C ++编写的代码,它输出一个包含三列(Time,Force,Height)数据的.csv文件。我想使用Octave绘制数据,或者使用C ++文件中的八度函数图(我知道这是可能的,但我不一定需要这样做)。

现在我有简单的.m文件:

filename = linear_wave_loading.csv;
M = csvread(filename);

练习将此文件变为八度(将尝试绘制后) 我收到了这个错误。

error: dlmread: error parsing range

将.csv文件加载到八度音程的正确方法是什么?

编辑:这是我的.csv文件的前几行

Wavelength= 88.7927 m
Time    Height  Force(KN/m)
0   -20 70668.2
0   -19 65875
0   -18 61411.9
0   -17 57256.4

提前感谢您的帮助。

2 个答案:

答案 0 :(得分:8)

使用八度音阶3.8.2

>> format long g
>> dlmread ('test.csv',' ',2,0)
ans =

                     0                     0                     0                   -20               70668.2
                     0                     0                     0                   -19                 65875
                     0                     0                     0                   -18               61411.9
                     0                     0                     0                   -17               57256.4

常规,如果您的值分隔符不是逗号,请使用dlmread。此外,您必须跳过两个标题。 理论上的dlmread也与制表符分隔值'\t'一起使用,但是由于不连续的制表符大小(可能它只是一个复制粘贴问题),这会给你带来例子,因此占用一个空格{{1}作为分隔符是一种解决方法。 你应该更好地保存你的.csv文件逗号分隔

' '

然后您可以轻松地Wavelength= 88.7927 m Time Height Force(KN/m) 0, -20, 70668.2 0, -19, 65875 0, -18, 61411.9 0, -17, 57256.4

您可以尝试我的csv2cell(不要与io包中的csv2cell混淆!)功能(从未尝试过它< 3.8.0)。

dlmread('file.csv',',',2,0)

通常它会自动重新成形,但是如果是空间分隔符,它通常会失败,所以你必须自己重塑它(并且在任何情况下都转换为double)。

当你需要标题时

>> str2double(reshape(csv2cell('test.csv', ' +',2),3,4))'
ans =

                 0                   -20               70668.2
                 0                   -19                 65875
                 0                   -18               61411.9
                 0                   -17               57256.4

但要小心,那么一切都是你牢房里的一根绳子。

答案 1 :(得分:1)

您没有将.csv文件名存储为字符串。 尝试:

filename = 'linear_wave_loading.csv';