我有兩個m file,A.m 和 B.m。A要用來給參數,B是function. A.m x=[a b c]; y={'desc1' 'desc2' 'desc3'}; Amax(x,y); B.m function Amat(x,y) dataset = xlsread('sale.xls'); x1=x'*x; xlswrite('result.xls',y); end 說明: 1. B file 會讀入data,總共有10個變數,但我們只要取用a, b and c 3個即可。 2. A file 指定x(matrix with a, b and c)和y(char)做為變數的名稱(for export)。 請問一下有人知道要如何在A給出x matrix傳送到B嗎?謝謝。
在B.m這個程序當中會先讀入data,才會有變數a,b andc,然後才可以做矩陣運算X1。也就是說在A.m裡面沒有任何data,A.m只負責指定需要進入矩陣運算的變數。我要做的事情其實是在A.m當中指定多個矩陣,例如[a c]或是[a b c d e],然後進入B.m去做運算然後得到結果輸出report。在A.m中指定x=[a b c]會得到錯誤訊息 "Cannot find an exact (case-sensitive) match for 'a'",若寫成x='a b c'則不會有錯誤訊息,但是這樣一來x就變成char,傳入B.m還是char而不是變數,這樣就無法做運算了。希望這次有把問題講清楚QQ
還是看不懂 所以你直接把x當input進去會有什麼問題?你B裡面不就是用x去做矩陣運算?你的a b c是在A.m中算出或填入的一些已知矩陣?那就要看你在B.m中的x大矩陣到底跟a b c這些小矩陣什麼關係吧 如果維度正確才是像你這樣直接串起來另外 除非真的非不得已不然還是不要用eval 正常來說沒有非得要用eval的情況
先謝過p大和n大熱心指教~~@p大: a, b, c要在B.m當中才會從excel讀進去。基本上A.m只是指定矩陣x要包含a,b,c而已。A.m本身沒有任何其他資料或是變數。@n大:readcell也許是個好主意,只是不知道why我的matlab沒有這功能(R2018a)。另外可否詳述一下所謂"xls讀取完處理成cell"是甚麼意思?是指儲存成cell型態嗎?