How to remove rows of empty strings?

51 次查看(过去 30 天)
I have a string array which I have preallocated as follows:
BusName = strings(MaxB,NumBVF,1);
After reading in the data, my string array has many empty rows at the end.
So my question is: How do I remove all rows that consist entirely of blank strings ("")?
Here is what I've come up with so far:
BusName(strcmp(BusName(:,2),""),:) = [];
Unfortunately, it is removing rows that it shouldn't be (rows that have "" but also data).
Any suggestions (and explanation) will be greatly appreciated!
  3 个评论
Calvin Ewanchuk
Calvin Ewanchuk 2019-10-30
Never uploaded a file here before, but here goes
the cyclist
the cyclist 2019-10-30
编辑:the cyclist 2019-10-30
Your upload worked! (And my solution works on your input.)

请先登录,再进行评论。

回答(2 个)

the cyclist
the cyclist 2019-10-30
编辑:the cyclist 2019-10-30
I'm having trouble following the logic in the command you posted, because you seem to be checking only the second column of Busname.
But I'm pretty sure you'll want to use the all command to get the rows where all the elements are blank.
I think it would be something like
BusName(all(strcmp(BusName,""),2),:) = [];
  1 个评论
Calvin Ewanchuk
Calvin Ewanchuk 2019-10-30
编辑:Calvin Ewanchuk 2019-10-30
Sorry, I'm kinda new to MATLAB. I'll try your code.
Yes, I want to delete the rows where all the strings are blank (""). I just can't figure out the syntax.

请先登录,再进行评论。


Walter Roberson
Walter Roberson 2019-10-30
编辑:the cyclist 2019-10-30
BusName = rmmissing(BusName, 'MinNumMissing', size(BusName,2));
  2 个评论
Calvin Ewanchuk
Calvin Ewanchuk 2019-10-30
I don't think this will work since the data is blank ("') but not <missing>.
the cyclist
the cyclist 2019-10-30
Yeah, does not work on your string array.
(Walter, my edit of your answer was just to fix up 'MinMissing' to 'MinNumMissing').

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 Matrix Indexing 的更多信息

产品

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by