converting a string of variables to numbers

HI all I have the varible
Country
Austria
Austria
Austria
Austria
Austria
Austria
Austria
and I want to convert it to a numeric varable. Any help?
Thanks in advance

5 commentaires

Thomas
Thomas le 21 Mai 2012
Can you give an example of what your output should be..
ektor
ektor le 21 Mai 2012
Hello, Thomas
I have the following table in excel
time country Location price2
1/09 Austria l1 12
2/09 Austria l1 4
3/09 Austria l1 2
1/09 Austria l2 1
2/09 Austria l2 23
3/09 Austria l2 14
1/09 Germany l1 100
2/09 Germany l1 110
3/09 Germany l1 120
1/09 Germany l2 100
2/09 Germany l2 110
3/09 Germany l2 120
I want to obtain the following structure
1/09 Austria l1 12
1/09 Germany l1 100
2/09 Austria l1 4o
2/09 Germany l1 1 10
3/09 Austria l1 2
3/09 Germany l1 120
1/09 Austria l2 1
1/09 Germany l2 100
2/09 Austria l2 23
2/09 Germany l2 110
and so forth...
the first 3 varibles are string varibles.
As you can see I want to gather together all l1s that correspond to 1/09
then, i want to gather all l1s that correspond to 2/09
then, i want to gather all l1s that correspond to 3/09
then, i want to gather all l2s that correspond to `1/09
then, i want to gather all l2s that correspond to `2/09
then, i want to gather all l2s that correspond to `3/09
and so forth.....
Oleg Komarov
Oleg Komarov le 21 Mai 2012
To be more precise you're grouping by location AND country AND date.
ektor
ektor le 21 Mai 2012
yes, thank you again
Oleg Komarov
Oleg Komarov le 21 Mai 2012
Now that I read your duplicated question: http://www.mathworks.com/matlabcentral/answers/38910-grouping-observations-with-specific-characteristics
I understand that you do NOT want to gather but sort.
Geoff already answered your question, you have to use sortrows.

Connectez-vous pour commenter.

 Réponse acceptée

Walter Roberson
Walter Roberson le 21 Mai 2012

0 votes

Use the multi-output form of unique() to convert string variables to numeric indices.
When you have the numeric indices, use accumarray() to sum the data into a 3D table (date, country, I-value).
Either compute further things with that table or output it, skipping the 0 entries (the ones for which there was no input data)

5 commentaires

ektor
ektor le 21 Mai 2012
I am a bit confused. the unique function finds the unique values. am i right?
I do not know how to proceed.
Geoff
Geoff le 21 Mai 2012
uniqueNames = unique(names);
nameId = cellfun( @(name) find(strcmp(uniqueNames,name)), names );
Walter Roberson
Walter Roberson le 21 Mai 2012
Easier:
[uniqueNames, junk, nameID] = unique(names);
Walter Roberson
Walter Roberson le 22 Mai 2012
Note: this solution is for adding together all of the values associated with a particular triple of attributes. If you only have one value for any given combination, then this approach is not appropriate, but sortrows() would be appropriate.
ektor
ektor le 22 Mai 2012
Tnank you both!

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

Community Treasure Hunt

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

Start Hunting!

Translated by