在 VSTO (Visual Studio Tools for Office) 中,你可以通过以下方法实现将当前单元格向上下左右各移动 2 个格子并返回移动后的 Range 对象:
csharp
using Excel = Microsoft.Office.Interop.Excel;
// ...
// 假设当前单元格是 activeCell,可以是你在 Excel 中选中的单元格
Excel.Range activeCell = Globals.ThisAddIn.Application.ActiveCell;
// 向上移动 2 个格子
Excel.Range movedUp = activeCell.Offset[-2, 0];
// 向下移动 2 个格子
Excel.Range movedDown = activeCell.Offset[2, 0];
// 向左移动 2 个格子
Excel.Range movedLeft = activeCell.Offset[0, -2];
// 向右移动 2 个格子
Excel.Range movedRight = activeCell.Offset[0, 2];
// 返回移动后的 Range 对象
Console.WriteLine("Moved Up: " + movedUp.Address);
Console.WriteLine("Moved Down: " + movedDown.Address);
Console.WriteLine("Moved Left: " + movedLeft.Address);
Console.WriteLine("Moved Right: " + movedRight.Address);
这里使用 Offset 属性来实现相对移动。Offset[rowOffset, columnOffset] 允许你在行和列的方向上相对移动单元格。上述代码中,Offset[-2, 0] 表示向上移动两行,Offset[2, 0] 表示向下移动两行,Offset[0, -2] 表示向左移动两列,Offset[0, 2] 表示向右移动两列。
你可以根据实际需要调整偏移值和处理逻辑。请注意,这里的偏移值为负表示向上或向左移动,为正表示向下或向右移动。