Effacer les filtres
Effacer les filtres

error in using year()

3 vues (au cours des 30 derniers jours)
Binzi Shu
Binzi Shu le 29 Fév 2016
Modifié(e) : Stephen23 le 1 Mar 2016
I typed exactly the same code as in the reference provided below:
Year = year('05-Aug-2003')
and I get
Year =
2002
2002
2002
2002
2002
2002
2002
2002
2002
2002
2002
Why is that? Thanks.
Reference:
  2 commentaires
Fangjun Jiang
Fangjun Jiang le 29 Fév 2016
what is the version of the Financial Toolbox?
ver('finance')
which -all year
Binzi Shu
Binzi Shu le 1 Mar 2016
v5.6 for financial toolbox

Connectez-vous pour commenter.

Réponses (1)

Fangjun Jiang
Fangjun Jiang le 1 Mar 2016
Modifié(e) : Fangjun Jiang le 1 Mar 2016
There must be a variable called "year" in the workspace. Try this:
year=2002*ones(120,1);
Year = year('05-Aug-2003')
It got your answer.
Try this
year=1:120;
Year=year('05-Aug-2003')
Year =
48 53 45 65 117 103 45 50 48 48 51
notice
>> double('05-Aug-2003')
ans =
48 53 45 65 117 103 45 50 48 48 51
It turned out it converted the string '05-Aug-2003' into double numbers and used the numbers to index the existing matrix "year". The size of "year" happens to be large enough so the "Index exceeds matrix dimensions" error didn't happen.
I don't like this behavior.
  2 commentaires
Binzi Shu
Binzi Shu le 1 Mar 2016
yes there is already a variable called year and it is a 1*n matrix. Does that mean that the year() function will not work properly if I ever created a variable called year? Thanks.
Stephen23
Stephen23 le 1 Mar 2016
Modifié(e) : Stephen23 le 1 Mar 2016
@Binzi Shu: that is correct. When you create a variable with the same name as an inbuilt function/variable, you cannot use the inbuilt one. For this reason avoid using length, size, cell, i, j, year, etc.
You can check if a name is already used with the which function.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Matrix Indexing dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by