【问题标题】:Iterating through an Excel range遍历 Excel 范围
【发布时间】:2011-06-27 19:24:58
【问题描述】:

我正在使用 Excel 应用程序 SheetChange 事件来捕获我的 Excel 应用程序工作表中的任何更改。 如果用户只修改了 1 个单元格,则可以通过以下方式检索单元格坐标:

void CellsChange(object Sh, Excel.Range Target)
{
 ....
 string changedCell = Target.get_Address(Missing.Value, Missing.Value, Excel.XlReferenceStyle.xlA1, Missing.Value, Missing.Value);
 ....
}

在上面的例子中,典型的返回值是“$C$11”。

但是,如果用户通过突出显示多个单元格来修改单元格范围,并使用 shift-enter 以相同的值填充整个范围,则返回的字符串可能类似于:“$C$11:$K$11 "(表示连续更改 9 个单元格)。

如何迭代抛出范围?在 foreach 或 for 循环中获取每个单元格坐标和值。 我尝试了以下...

for (int i = 0; i < Target.Count; i++)
{
   Excel.Range r = Target.Item[i];
   MessageBox.Show(Convert.ToString(r.Value2));
}

但是这段代码并没有给我原始范围单元格的新值。 我也没有遵循 Target.Item 逻辑 - 它是基于零的数组还是基于一的数组。 在几次尝试中,看起来 Item 数组是整个表格单元格范围,格式为数组(因此也可以使用 Item[0],它是突出显示范围左侧的一个单元格)。

有没有人有更多使用 Range 对象和/或上述事件的经验?

谢谢

【问题讨论】:

  • 您使用什么库来处理 Excel?
  • 当您在 Excel 中执行某些操作时需要了解语法、对象或逻辑时,请尝试录制宏。通常它生成的内容可以让您很好地了解如何解决您的问题。

标签: c# excel


【解决方案1】:

由于您已经在事件处理程序中获取 Range 对象,因此您不想重新查询工作表以获取您的范围 - 您不会获得新值。

请尝试循环遍历 Range.Cells 属性,如下所示:

foreach (Range c in Target.Cells)
{
   string changedCell = c.get_Address(Type.Missing, Type.Missing, XlReferenceStyle.xlA1, Type.Missing, Type.Missing);  
   MessageBox.Show("Address:" + changedCell + " Value: " + c.Value2);
}

【讨论】:

  • 谢谢,这正是我要找的。​​span>
  • 确实上面更新的代码与我的设置更相关,但我自己弄清楚了
【解决方案2】:

要迭代Range,它是从1开始的,即:

for (int i = 1; i <= Target.Count; i++)
{
  Excel.Range r = (Excel.Range)Target.Item[i];
  MessageBox.Show(Convert.ToString(r.Value2));
}

【讨论】:

    猜你喜欢
    • 2013-08-17
    • 2020-12-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-04-07
    • 2017-03-26
    • 1970-01-01
    相关资源
    最近更新 更多