c# - 遍历 Excel 范围

标签 c# excel

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

谢谢

最佳答案

由于您已经在事件处理程序中获取了 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);
}

关于c# - 遍历 Excel 范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6497849/

相关文章:

excel - 如何在excel中找到隐藏的字符

c# - 如何将 C# 类库项目转换为 Silverlight 项目?

c# - 如何将 EF Core 与适用于 .NET 5+ 的 Azure SQL 分片结合使用?

c# - 命名空间 c# 中的方法

excel - Google Apps 脚本创建 excel 文件的工作表版本

excel - 如何修复第二个errHandler

python - 为什么我的 openpyxl 加载只拉工作表中的一个单元格

c# - 服务器违反了协议(protocol)。 C# 中的 Section=ResponseStatusLine

C# WebBrowser 控制 System.AccessViolationException

Excel 2010索引匹配VBA