乘以Excel中乘以数组得到的数组

时间:2018-01-30 01:20:30

标签: arrays excel

我已经尝试查看了一些帖子,但我在找到能够帮助我解决这个问题的方法时遇到了麻烦。

我有一个电子表格,其中包含一年中每周的总销售额,零售价和库存,以列出100个左右的项目。这三条信息显示为年份重复的列,每个项目都有一行。 Excel Snip

我能够使用SUMPRODUCT((MOD(COLUMN(D3:L3),3)=0)*D3:L3)

将每年的总细胞数(每第3列)相加

下一个目标是获得一个公式来计算加权平均零售。我基本上需要找到一个最终会得到销售数据和零售数据数组SUMPRODUCT的公式。

我尝试使用MMULTSUMPRODUCT的某些分层,但不断出现#VALUE!错误。特别是使用SUMPRODUCT(TRANSPOSE(MMULT(TRANSPOSE((MOD(COLUMN(D3,L3),3)=0)),D3,L3)),MMULT(TRANSPOSE((MOD(COLUMN(D3,L3),3)=1)),D3,L3))并在其中添加括号=SUMPRODUCT({TRANSPOSE(MMULT(TRANSPOSE((MOD(COLUMN(D3,L3),3)=0)),D3,L3))},{MMULT(TRANSPOSE((MOD(COLUMN(D3,L3),3)=1)),D3,L3)})

有没有人对此类问题有过任何经验?我觉得它应该是Excel可以做的事情而不必单独计算表单。

1 个答案:

答案 0 :(得分:0)

您的加权平均值:

--- Exception in Async Thread ---
java.util.concurrent.RejectedExecutionException: Task tornadofx.FXTask@a315135 rejected from java.util.concurrent.ThreadPoolExecutor@75bde925[Terminated, pool size = 0, active threads = 0, queued tasks = 0, completed tasks = 2]
    java.base/java.util.concurrent.ThreadPoolExecutor$AbortPolicy.rejectedExecution(ThreadPoolExecutor.java:2104)
    java.base/java.util.concurrent.ThreadPoolExecutor.reject(ThreadPoolExecutor.java:848)
    java.base/java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1397)
    tornadofx.AsyncKt.task(Async.kt:76)
    tornadofx.AsyncKt.task(Async.kt:69)
    tornadofx.Component.runAsync(Component.kt:272)
    tornadofx.Component.runAsync$default(Component.kt:988)
    me.carltonwhitehead.MainView$root$1$1$1.invoke(AsyncBugApp.kt:21)
    me.carltonwhitehead.MainView$root$1$1$1.invoke(AsyncBugApp.kt:15)
    tornadofx.ControlsKt$action$2.handle(Controls.kt:513)
    tornadofx.ControlsKt$action$2.handle(Controls.kt)
    javafx.base/com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86)
    javafx.base/com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
    javafx.base/com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
    javafx.base/com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59)
    javafx.base/com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
    javafx.base/com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    javafx.base/com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    javafx.base/com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    javafx.base/com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    javafx.base/com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    javafx.base/com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
    javafx.base/com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49)
    javafx.base/javafx.event.Event.fireEvent(Event.java:198)
    javafx.graphics/javafx.scene.Node.fireEvent(Node.java:8863)
    javafx.controls/javafx.scene.control.Button.fire(Button.java:200)
    javafx.controls/com.sun.javafx.scene.control.behavior.ButtonBehavior.mouseReleased(ButtonBehavior.java:206)
    javafx.controls/com.sun.javafx.scene.control.inputmap.InputMap.handle(InputMap.java:274)
    javafx.base/com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.handleBubblingEvent(CompositeEventHandler.java:218)
    javafx.base/com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:80)
    javafx.base/com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238)
    javafx.base/com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191)
    javafx.base/com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59)
    javafx.base/com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58)
    javafx.base/com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    javafx.base/com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    javafx.base/com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    javafx.base/com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56)
    javafx.base/com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114)
    javafx.base/com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74)
    javafx.base/com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54)
    javafx.base/javafx.event.Event.fireEvent(Event.java:198)
    javafx.graphics/javafx.scene.Scene$MouseHandler.process(Scene.java:3876)
    javafx.graphics/javafx.scene.Scene$MouseHandler.access$1300(Scene.java:3604)
    javafx.graphics/javafx.scene.Scene.processMouseEvent(Scene.java:1874)
    javafx.graphics/javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2613)
    javafx.graphics/com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:397)
    javafx.graphics/com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:295)
    java.base/java.security.AccessController.doPrivileged(Native Method)
    javafx.graphics/com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEvent$2(GlassViewEventHandler.java:434)
    javafx.graphics/com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389)
    javafx.graphics/com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java:433)
    javafx.graphics/com.sun.glass.ui.View.handleMouseEvent(View.java:556)
    javafx.graphics/com.sun.glass.ui.View.notifyMouse(View.java:942)
    javafx.graphics/com.sun.glass.ui.gtk.GtkApplication._runLoop(Native Method)
    javafx.graphics/com.sun.glass.ui.gtk.GtkApplication.lambda$runLoop$11(GtkApplication.java:277)
    java.base/java.lang.Thread.run(Thread.java:844)

另外,要加上销售额,您可以考虑:

=SUMPRODUCT(($D$2:$FD$2="Sales")*$D3:$FD3*$E3:$FE3)/SUMIF($D$2:$FD$2,"Sales",$D3:$FD3)

我假设=SUMIF($D$2:$FD$2,"Sales",$D3:$FD3) 是该年度的最后一列数据,但如果不是这样,请更改它。