似乎出于某种原因,Excel 程序员选择省略任何向量叉积功能。
此外,在网上看,对它的需求并不多。虽然excel是做线性代数的强大工具。
我需要一个 VBA 脚本来做向量交叉产品。我唯一能找到的是从这里:
编辑:
- 要添加 VBA 脚本,请按 Alt + F11
- 在 Project 下,右键单击 VBAProject 和 Insert->Module
- 保存,单击否以另存为启用宏的工作簿
- 另存为 .xlsm 文件
--------------------
Function vCP(v1 As Variant, v2 As Variant) As Variant
vCP = Array(v1(2) * v2(3) - v1(3) * v2(2), _
v1(3) * v2(1) - v1(1) * v2(3), _
v1(1) * v2(2) - v1(2) * v2(1))
End Function
--------------------
使用起来很简单,
- 选择3个水平相邻的单元格,输入公式
=vCP(
- 选择位于 3 个连续水平或垂直单元格中的向量 A(在 A x B 中)
- 类型
,
- 选择向量 B,它是 3 个连续水平的垂直单元格
- 类型
)
- 按 Ctrl+Shift+Enter
我对其进行了几次测试,它可以工作,但它输出的是水平向量,而不是垂直向量,这是线性代数首选的方式。
有谁知道如何更改此脚本,以便可以垂直输出 3D 矢量?
有没有更好的方法在 Excel 中获得叉积?
感谢:D