空白的单元格在读取带有TextScan的字符串的substring和数字时



我有一个文本文件,该文件由类似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" />

我只对''中的值感兴趣。&quot因此,我正在尝试使用TextScan阅读此内容。为此,我采用第一行,然后再判处/替换以将%f和符合%s的字符串交换,例如:

expression = '"[-+]?d*.?d*"';
expression2 = '"w*?"';
newStr = regexprep(firstline,expression,'"%f"');
FormatString = sprintf('%s',regexprep(newStr,expression2,'"%s"'));

i重新打开文件以读取带有以下呼叫的字符串的文件:

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}

好吧,今天用一些新鲜的眼睛看着这个问题。

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

需要切换到%q 选项,该选项允许读取双引号中的字符串,并且需要将textScan的定界符归还为单个空间。代码现在正常工作。

相关内容

  • 没有找到相关文章

最新更新