如何使用Dynamic Array函数在Excel中重新设计列到矩阵
我有一个带有一些列数据的Excel表,我想使用Mmult功能将其用于某些矩阵乘法。为此,我需要首先重塑列数据。我想使用动态数组函数进行重塑进行重塑,因为然后可以直接进入Mmult功能,而无需实际在表中显示重塑矩阵(即仅将列保留在用户可见的输入数据)。我知道诸如此处概述的想法 http://www.cpearson.com/excel /vectortomatrix.aspx 但是,据我所知,这需要在我不想要的表格中显示重塑数据。一种替代方法可能是使用卷曲括号直接进入公式中的数组,但是据我所知,该符号不允许允许单元引用,即类似于mmult({a1,a1,a2,a3; a4; a4; a4,a5,a6}) ,{a7,a8; a9,a10; a11,a12})不允许。解决这个问题的想法吗?
一个示例如下所示,基本上我的工作表中有列数据,但是不想重复数据(作为重塑数据),但是,我仍然希望能够显示重塑矩阵的平方。
I have an excel sheet with some column data that I would like to use for some matrix multiplications using MMULT-function. For that purpose I need to reshape the column data first. I would like to do the reshaping using a dynamic array function since that could then feed directly into the MMULT function without having to actually display the reshaped matrix in the sheet (i.e. keeping only the column with the input data visible for the user). I am aware of ideas such as the one outlined here http://www.cpearson.com/excel/VectorToMatrix.aspx however however as far as I can see that requires having the reshaped data displayed in the sheet which I do not want. An alternative could be to enter the arrays directly in the formula using curly brackets, however as far as I can see this notation does not allow cell-references, i.e. something like MMULT({A1,A2,A3;A4,A5,A6},{A7,A8;A9,A10;A11,A12}) is not allowed. Any ideas for solving this issue?
An example is shown below, basically I have the column-data in my sheet, but do not want to repeat the data (as reshaped data), however, I would still like to be able to do display the square of the reshaped matrix.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
用于重塑
9x1
数组中3x3
数组:index(b3:b11,sequence(rows(b3:b11)/3,3))
For reshaping a
9x1
array into a3x3
array:INDEX(B3:B11,SEQUENCE(ROWS(B3:B11)/3,3))