Table variable subscripts must be real positive integers
    5 views (last 30 days)
  
       Show older comments
    
Using the data from https://la.mathworks.com/help/finance/black-litterman-portfolio-optimization.html, and running the code head(T(:,["Dates" benchmarkName assetNames])), get the following error: Table variable subscripts must be real positive integers, logicals, character vectors, or cell arrays of character vectors. I dont now how to fix it.
thanks
9 Comments
  Dave B
    
 on 29 Jul 2021
				
      Edited: Dave B
    
 on 29 Jul 2021
  
			That helps, this sort of fits with my previous hypothesis i.e. that you need to provide char not string:
Let's work our way back to the final bit building off of:
head(T(:,'Dates'))
head(T(:,'DJI')) % just a different table variable
head(T(:,{'Dates' 'DJI'}) % Two table variables
% specifying 'DJI' in a workspace variable
benchmarkName = 'DJI'; 
head(T(:,{'Dates' benchmarkName}))
% specifying all of the assetNames
assetNames = {'AA' 'AIG' 'WMT' 'MSFT' 'BA' 'GE' 'IBM'};
head(T(:,assetNames))
% one way to put these all together
head(T(:,{'Dates' benchmarkName assetNames{:}})) 
% the line of code from my previous comment 
% (just in case something got confused and this works now)
head(T(:,['Dates' benchmarkName assetNames]))
Answers (1)
  Eike Blechschmidt
      
 on 29 Jul 2021
        I guess you just forgot the quotation marks around benchmarkName and assetNames.
See Also
Categories
				Find more on Tables in Help Center and File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

