1

我有一个文本文件,它由一行又一行的数据组成,格式类似于 xml,如下所示:

<item type="newpoint1" orient_zx="0.8658983248810842" orient_zy="0.4371062806139187" orient_zz="0.2432245678709263" electrostatic_force_x="0" electrostatic_force_y="0" electrostatic_force_z="0" cust_attr_HMTorque_0="0" cust_attr_HMTorque_1="0" cust_attr_HMTorque_2="0" vel_x="0" vel_y="0" vel_z="0" orient_xx="-0.2638371745169712" orient_xy="-0.01401379799313232" orient_xz="0.9644654264455047" pos_x="0" cust_attr_BondForce_0="0" pos_y="0" cust_attr_BondForce_1="0" pos_z="0.16" angvel_x="0" cust_attr_BondForce_2="0" angvel_y="0" id="1" angvel_z="0" charge="0" scaling_factor="1" cust_attr_BondTorque_0="0" cust_attr_BondTorque_1="0" cust_attr_BondTorque_2="0" cust_attr_Damage_0="0" orient_yx="0.4249823952954215" cust_attr_HMForce_0="0" cust_attr_Damage_1="0" orient_yy="-0.8993006799250595" cust_attr_HMForce_1="0" orient_yz="0.1031903618333235" cust_attr_HMForce_2="0" />

我只对“”中的值感兴趣,所以我试图用 textscan 来阅读它。为此,我使用第一行并执行正则表达式查找/替换以将所有数字交换为 %f 并将字符串交换为 %s,如下所示:

expression = '"[-+]?\d*\.?\d*"';
expression2 = '"\w*?"';

newStr = regexprep(firstline,expression,'"%f"');
FormatString = sprintf('%s',regexprep(newStr,expression2,'"%s"'));

我使用以下调用重新打开文件以使用字符串读取文件:

while ~feof(InputFile) % Read all lines in file    
    data = textscan(InputFile,FormatString,'delimiter','\n');    
end

但我得到的只是一组空单元格。我看不出我的错误是什么——有人能指出我正确的方向吗?

澄清:

Mathworks 为 textscan 提供了以下示例以删除文字文本,这是我正在尝试做的。

“从上一个示例的数据第二列中的每个字段中删除文字文本‘级别’。”

filename = fullfile(matlabroot,'examples','matlab','scan1.dat');
fileID = fopen(filename);
C = textscan(fileID,'%s Level%d %f32 %d8 %u %f %f %s %f');
fclose(fileID);
C{2}
4

1 回答 1

1

好的,今天用新的眼光看了这个之后,我发现了我的问题。

newStr = regexprep(firstline,expression,'"%f"');
FormatString = sprintf('%s',regexprep(newStr,expression2,'%q'));

data = textscan(InputFile,FormatString,'delimiter',' ');

字符串的替换需要切换到%q选项,该选项允许读取双引号内的字符串,并且 textscan 的分隔符需要恢复为单个空格。代码现在工作正常。

于 2017-06-27T16:32:33.023 回答