- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 VSTO 加载项项目中,如果我选择一个空单元格(如 F11)并在该范围内运行查找任何值,它似乎会搜索整个工作表并在我期望它时返回范围 A1:E10返回空值。下面是我选择的单元格的图像。
我正在通过选择访问这个范围,当我在调试时检查时,它有一个 6 列和 11 行,这是我选择的。当我试图在这个范围内找到任何东西时,我希望我应该得到一个空值,但我却得到了 E10 的值,这是没有意义的。
这是我的 C# 代码,第一部分获得一个选择并遍历范围区域,在单选的情况下只有1个区域。
即使 F11 是唯一选中的单元格,最后的 val1 和 val2 的值都是 3197077000。
using Microsoft.Office.Interop.Excel;
using System;
using System.Windows.Forms;
using Excel = Microsoft.Office.Interop.Excel;
namespace ExcelAddIn1
{
public partial class UserControl1 : UserControl
{
public UserControl1()
{
InitializeComponent();
}
private void button1_Click_1(object sender, EventArgs e)
{
Excel.Range selection = Globals.ThisAddIn.Application.Selection;
if (null != selection)
{
var sheet = selection.Worksheet;
var book = (Excel.Workbook)sheet.Parent;
var areasCount = selection.Areas.Count;
for (int i = 1; i <= areasCount; i++)
{
var area = selection.Areas[i];
var test = area.Value;
var testCount = area.Count;
var testRow = area.Row;
var testCol = area.Column;
Excel.Range lastCellInLastRow = area.Find(
"*",
Type.Missing,
XlFindLookIn.xlFormulas,
XlLookAt.xlPart,
XlSearchOrder.xlByRows,
XlSearchDirection.xlPrevious,
false,
Type.Missing,
Type.Missing);
Excel.Range lastCellInLastCol = area.Find(
"*",
Type.Missing,
XlFindLookIn.xlFormulas,
XlLookAt.xlPart,
XlSearchOrder.xlByColumns,
XlSearchDirection.xlPrevious,
false,
Type.Missing,
Type.Missing);
var val1 = lastCellInLastCol.Value;
var val2 = lastCellInLastRow.Value;
}
}
}
}
}
当我在 VBA 中做同样的事情时,我按预期在 F11 上运行查找时得到一个 null
Option Explicit
Public Sub SelectionTest()
Dim selection As Variant
Dim rng As Range
Dim UsedRange As Variant
Dim lastCell As Range
Set selection = Application.selection
Dim area As Range
Debug.Print "selection columns " & selection.Columns.Count
Dim finalRng As Range
Dim finalArr As Variant
For Each area In selection.Areas
Debug.Print "single rng columns " & area.Columns.Count
Set lastCell = area.Find(What:="*", After:=area.Cells(1, 1), LookIn:=xlFormulas, LookAt:= _
xlPart, SearchOrder:=xlByRows, SearchDirection:=xlPrevious, MatchCase:=False)
Set lastCell = area.Find(What:="*", After:=area.Cells(1, 1), LookIn:=xlFormulas, LookAt:= _
xlPart, SearchOrder:=xlByColumns, SearchDirection:=xlPrevious, MatchCase:=False)
Debug.Print lastCell
Next
End Sub
最佳答案
简短回答:Interop/Range.Find 可能不可靠。尽可能少地使用 Interop。
更长的答案:我在实践中注意到关于 Range.Find
的不可靠的事情之一是它似乎对之前最后搜索的内容有内存。这可能是也可能不是这里的问题,但如果我是你,我不会费心去弄明白,因为你可以按如下方式解决你的问题:
C#
正则表达式库和嵌套 for 循环来搜索数组需要做更多的工作,但为了摆脱不可靠的 Interop 基础,这是值得的。这里有一些代码可以帮助您开始阅读范围:
public string[,] ReadValues(Range range)
{
return ConvertToStringArray2D(GetArray(range, () => range.Value2));
}
private string[,] ConvertToStringArray2D(Array values)
{
string[,] retArray = new string[values.GetLength(0), values.GetLength(1)];
// loop through the 2-D System.Array and populate the 1-D String Array
for (int row = 1; row <= values.GetLength(0); row++)
{
for (int col = 1; col <= values.GetLength(1); col++)
{
if (values.GetValue(row, col) == null)
{
retArray[row - 1, col - 1] = "";
}
else
{
retArray[row - 1, col - 1] = values.GetValue(row, col).ToString();
}
}
}
return retArray;
}
private Array OneBasedSingletonArray2D()
{
return Array.CreateInstance(typeof(Object), new int[] { 1, 1 }, new int[] { 1, 1 });
}
private Array GetArray(Range range, Func<object> dataProducer)
{
if (range.Cells.Count == 0)
{
return Array.CreateInstance(typeof(Object), 0, 0);
}
if (range.Cells.Count == 1)
{
//Creating a 1-based array to fit with Excel's 1-based indexing
Array retArray = OneBasedSingletonArray2D();
retArray.SetValue(dataProducer.Invoke(), 1, 1);
return retArray;
}
else
{
return (Array)dataProducer.Invoke();
}
}
关于c# - vsto Range.Find on empty single cell selection 返回单元格外的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51527952/
cell.layoutIfNeeded() 和 cell.layoutSubviews() 和 cell.setNeedsDisplay() 方法一般有什么作用? 最佳答案 布局 subview 布置
是否可以在GXT 3.0中逐个单元地定义编辑器类型? 我需要创建一个转置表;列变成行,行变成列。在这种情况下,一列(从普通表格的角度来看)将具有不同的编辑器类型,而一行将具有相同的编辑器类型。 我正在
我的表格 View 中前 3 个单元格有一个标签,上面写着“松鼠”这个词。有没有办法做到这一点,如果 UILabel 在我的表格中的多个单元格中显示“Squirrels”,则只显示三个单元格中的第一个
让键和值相同有什么意义? JVM 会优化内存并使它们在堆中仅一份吗? 最佳答案 Map通常用于实现Set具有与背景图相同的属性。例如。如果映射是线程安全的,则相应的集合也将是线程安全的。如果 map
这个问题在这里已经有了答案: Testing for nil in Objective-C -- if(x != nil) vs if(x) (4 个答案) 已关闭 9 年前。
我用谷歌表格记录我们俱乐部的出席率。该表格链接到另一个谷歌表格,因此可以自动创建一个名字列表,并按字母顺序排序。在这张表格中,我还根据我们所做的活动,在人的名字旁边手动输入点数。。问题是,由于姓名列表
下面的代码如何工作: .Range("D4:F4").copy .cells(1,1).PasteSpecial 虽然下面不起作用: .Range("D4:F4").copy .cells(1,1)
我正在将一些值传递到 MySQL 数据库表中,我在考虑将整个 javascript 对象数组作为字符串传递是否更快,或者我是否应该根据速度将它们拆分为单元格。 例子: JavaScript 数组: v
display: table-cell; 和单元格之间的空间有问题。我希望所有单元格具有动态相同的宽度。 参见 JSFiddle "Ausstattung & Skizze" 比其他的要宽得多。有没有
我正在使用 apache poi 3.11,从 CellReference,我可以使用以下代码获取 rowIndex 和 Column Index。 CellReference cr = new Ce
我有一个带有圆形和阴影掉落单元格的 Collection View 。当单元格即将被导航栏覆盖时,单元格的阴影突然消失,而不是平滑地移出 View 。下面是代码: contentView.la
我刚开始使用 Swift 作为编程语言,但我遇到了自定义单元格的问题。 当我尝试创建自定义单元格,然后继续尝试按照我需要的方式设计它们(样式设置为自定义)时,一切看起来都不错。现在我不知道如何将特定数
目前,如果满足某些条件,我正在尝试设置一系列单元格的样式。我能够成功地将样式应用于一个单元格,但迄今为止未能成功地将其应用于一个范围。这是我所知道的有效方法: ElseIf OneA / OneC >
如果单元格 A1 为空白并且同一行中的任何单元格不为空白,我需要突出显示它。该行中的大多数单元格中都会包含公式。 最佳答案 创建一个新的条件格式,并使用这个公式: =AND($A$1="",COUNT
我确定这一定是可能的,但我找不到这样做的方法。 我有 2 列,一列带有数字,第二列带有日期。 例如: 数字日期 1 7月21日 2 7 月 22 日 3 7 月 23 日 4 7 月 24 日 5 7
我可能对范围有点困惑(我读过很多关于它的教程,但此时我不明白如何制作这个东西),无论如何,这就是我想要做的: 我有一个包含各种单元格的表格 Bla 1
宏记录器生成以下语句: Cells.Select 现在我明白,如果没有对象限定符,这会将所有单元格作为 Range 对象返回。 但是,我想知道这个语句的完全限定版本是什么? 是吗: Applicati
我知道 Range() 和 Cells() 属性是访问工作表上单元格的等效方法。但是,什么时候在这种组合中使用 Range.Cells() 是明智的呢? 我遇到了一个使用 Range("A1").Re
我有一个动态表,其中每一行都有一个文本框 (txtCantitate) 和一个按钮 (btnMinus)。在文本框中我有数量 (int) 并在按钮上单击我希望数量减少一个。在这里你有我在 table
我有两个 viewController。第一个 VC 在 tableCell 内有 collectionCell。第二个 VC 有 collectionCell,我有 swift File 和 Mod
我是一名优秀的程序员,十分优秀!