2011-06-27 101 views
7

我正在使用Excel应用程序SheetChange事件来捕获Excel应用程序表中的任何更改。 如果用户仅修改1细胞,然后检索单元坐标可以通过来完成:遍历Excel范围

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对象和/或上述事件的经验?

感谢

+0

你用什么库使用Excel? – Jethro

+5

当您在Excel中执行某些操作时需要知道语法,对象或逻辑是什么时,请尝试录制宏。通常它会产生一个很好的想法来解决如何解决问题。 –

回答

13

编辑: 对不起,我误解了问题。由于您已经在事件处理程序中获取了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); 
     } 
+0

谢谢,这正是我期待的。 – NirMH

+0

@Alexandre:我一定会在Excel宏中使用你的提示... – NirMH

+0

的确,上面更新后的代码与我的设置更相关,但我知道我自己 – NirMH

1

要迭代的范围,这是基于1,即:

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