Find column names with particular names in MATLAB table

조회 수: 34 (최근 30일)
Dhruv Ghulati
Dhruv Ghulati 2015년 12월 21일
댓글: Peter Perkins 2019년 2월 17일
Hi there,
I have a massive table with 408 columns in MATLAB. I want to get rid of columns that start with the word "connected". Instead of having to manually check the table and do something like
finalnbs(:,212:364) = [];
Where
finalnbs
is the table, how do I find all columns in finalnbs which start with connected e.g.
connected*
And then remove those?
  댓글 수: 1
harjeet singh
harjeet singh 2015년 12월 21일
please upload mat table, and let me know the datatype of finalnbs

댓글을 달려면 로그인하십시오.

채택된 답변

Walter Roberson
Walter Roberson 2015년 12월 21일
finalnbs(:,strncmp(finalnbs.Properties.VariableNames, 'connected', length('connected')) ) = [];

추가 답변 (2개)

Renato Agurto
Renato Agurto 2015년 12월 21일
편집: Renato Agurto 2015년 12월 21일
Hello
if "titles" is the first row of your table, then:
titles = finalnbs(1,:);
%Select the columns that should stay
idxs = cellfun(@(x) length(x) < 9 || ~strcmp(x(1:9),'connected'),titles);
finalnbs = finalnbs(:,idxs);

Joseba Moreno
Joseba Moreno 2019년 2월 14일
Hello,
I have a similar problem but in my case I would like to remove the columns which contain the word "free".
How can I do that?
Thanks!
Joseba
  댓글 수: 2
Walter Roberson
Walter Roberson 2019년 2월 14일
With new enough matlab you can use contains() to test whether a substring occurs somewhere in a string .
Peter Perkins
Peter Perkins 2019년 2월 17일
or strfind in older versions.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Electrical Block Libraries에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by