How to delete an element from a cell

I have a column in matlab with data written this way:
19970422
30980524
63098754
etc …
And I only want to have the first 4 numbers (preferably as a new variable), for instance like this:
1997
3098
6309
How can I do it? Thanks a lot for your help.

 Accepted Answer

Apdullah YAYIK
Apdullah YAYIK on 27 Apr 2014
Edited: Jan on 27 Apr 2014
Thats easy
X=[19970422 30980524 63098754]
New_X=floor(X/1000)

2 Comments

This gives the 5 first digits, use : floor(X/10000) . Also this works only for numbers with 8 digits.
And she said she had cells, not regular numerical arrays, though perhaps she didn't really mean cells - who knows.

Sign in to comment.

More Answers (1)

a=[19970422;30980524;63098754]
b=arrayfun(@num2str,a,'un',0)
out=cellfun(@(x) str2num(x(1:4)),b)
%or
a=[19970422;3098052422;630987541;0.23]
n=max(0,fix(log10(a)+1)-4)
out=fix(a./10.^n)

2 Comments

@Azzi Abdelmalek by any chance do you know how to do exactly the same thing, but with a cell element? Thanks in advance for your help!
About this question, problem solved!

Sign in to comment.

Asked:

on 26 Apr 2014

Commented:

on 24 Jun 2014

Community Treasure Hunt

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

Start Hunting!