필터 지우기
필터 지우기

reshaping a vector of dates (2)

조회 수: 1 (최근 30일)
antonet
antonet 2012년 7월 20일
Dear all, I have a cell column vector that contains the following elements
AAA={'AUGUST-SEPTEMBER 1999' ...
'OCTOBER-NOVEMBER 1999'...
'DECEMBER-JANUARY 2000'...
'FEBRUARY-MARCH 2000'...
'APRIL-MAY 2000'...
'JUNE-JULY 2000'}
I want to change that vector so as to have
AAA={'AS 1999'...
'ON 1999'...
'DJ 2000'...
'FM 2000'...
'AM 2000'...
'JJ 2000'}
Where AS for example stands for 'AUGUST-SEPTEMBER’
thanks
[EDITED, code formatted, Jan]
  댓글 수: 2
Jan
Jan 2012년 7월 20일
편집: Jan 2012년 7월 20일
@antonet: Please learn how to format your code properly. The more readable the question is, the easier is it to answer. This is your 50th question and I asked you repeatedly to care for a proper formatting.
antonet
antonet 2012년 7월 20일
thanks simon. Sorry for this.

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

채택된 답변

Andrei Bobrov
Andrei Bobrov 2012년 7월 20일
편집: Andrei Bobrov 2012년 7월 20일
g = regexp(AAA,'(^\w)|(-\w)|( \d*)','match');
AAA = strrep(cellstr(cell2mat(cat(1,g{:}))),'-','');
EDIT
  댓글 수: 3
antonet
antonet 2012년 7월 20일
Hi Andrei. I get the following error mesage
??? Index exceeds matrix dimensions.
Error in ==> @(x)strcat(f1{x,1:2},',',f1{x,3:4})
thanks
Andrei Bobrov
Andrei Bobrov 2012년 7월 20일
Thank you Jan for your comment.

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

추가 답변 (1개)

Jan
Jan 2012년 7월 20일
편집: Jan 2012년 7월 20일
AAA={'AUGUST-SEPTEMBER 1999'; ...
'OCTOBER-NOVEMBER 1999'; ...
'DECEMBER-JANUARY 2000'; ...
'FEBRUARY-MARCH 2000'; ...
'APRIL-MAY 2000'; ...
'JUNE-JULY 2000'};
Replace = {'AUGUST-SEPTEMBER', 'AS'; ...
'OCTOBER-NOVEMBER', 'ON'; ...
'DECEMBER-JANUARY', 'DJ';, ...
'FEBRUARY-MARCH', 'FM'; ...
'APRIL-MAY', 'AM'; ...
'JUNE-JULY', 'JJ'};
for i = 1:size(Replace, 1)
AAA = strrep(AAA, Replace{i, 1}, Replace{i, 2});
end
[EDITED] faster:
...
for i = 1:size(Replace, 1)
key = Replace{i, 1};
match = strncmp(AAA, key, length(key));
AAA(match) = strrep(AAA(match), key, Replace{i, 2});
end
While the 1st method needs 3.93 seconds if AAA is a {1572864 x 1} cell string, the smarter 2nd methods needs 1.42 seconds.
  댓글 수: 4
antonet
antonet 2012년 7월 20일
thanks simon for your reply. The above AAA is a sample. My original vector is of size 300 by 1. So it will take a lot of time to construct the "Replace" cell. this is the only problem that I have and to be honest it is ok for me if the code is slow as long as I do not need to do something extra.
Thanks
Jan
Jan 2012년 7월 20일
편집: Jan 2012년 7월 20일
I still do not understand, why the construction of "Replace" should take a lot of time and why this is influenced by the size of AAA. A vector of length 300 cannot be called "huge".
It seems to me like you did not post the complete problem. Unfortunately your decision to omit obviously necessary details leads to the fact, that the creation of my answer has wasted my time - and your time also. Please post all relevant details in future questions, especially the sizes of the real data.

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

카테고리

Help CenterFile Exchange에서 Logical에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by