- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试从 Word 表格中获取选定的单元格。我需要收集选定的表格单元格来创建自定义书签对象,其中包含用户选择的单元格范围的信息。当用户选择单元格的矩形区域时,一切正常。这就是我在 Word 插件中获取选定表格单元格的方式:
Globals.ThisAddIn.Application.Selection.Range.Application.ActiveWindow.Selection.Cells
如果用户选择了非矩形区域或选择了多个区域(同时按住 CTRL 键),此属性将返回无效的单元格集合。我创建了一个简单的 vba 代码,用于使用两个属性测试在表中选择了哪些单元格:
Globals.ThisAddIn.Application.Selection.Range.Application.ActiveWindow.Selection.Cells
Globals.ThisAddIn.Application.Selection.Range.Cells
当用户选择非矩形表格单元格区域时,这两个属性都会返回不同且无效的选定单元格集合。这是我用于测试目的的 vba 代码,当在 Word 表格中选择了单元格范围时:
Sub test()
Dim listaKomorek1 As New Collection
Dim listaKomorek2 As New Collection
Dim indekser1 As Integer
Dim indekser2 As Integer
Dim tekst1 As String
Dim tekst2 As String
Dim tabela As Table
Set tabela = Selection.Range.Tables(1)
indekser1 = 1
indekser2 = 1
liczbaKomorek1 = Selection.Range.Cells.count()
liczbaKomorek2 = Selection.Range.Application.ActiveWindow.Selection.Cells.count()
tekst1 = "Lista komorek 1 (Selection.Range.Cells): " & vbCrLf & vbCrLf & vbCrLf
tekst2 = "Lista komorek 2 (ActiveWindow.Selection.Cells): " & vbCrLf & vbCrLf & vbCrLf
For Each komorka In Selection.Range.Cells
tekst1 = tekst1 & "#Cell: " & CStr(indekser1) & " Value: " & CStr(komorka.Range.Text) & " Column: " & CStr(komorka.ColumnIndex) & " Row: " & CStr(komorka.RowIndex) & vbCrLf
indekser1 = indekser1 + 1
Next komorka
For Each komorka In Selection.Range.Application.ActiveWindow.Selection.Cells
tekst2 = tekst2 & "#Cell: " & CStr(indekser2) & " Value: " & CStr(komorka.Range.Text) & " Column: " & CStr(komorka.ColumnIndex) & " Row: " & CStr(komorka.RowIndex) & vbCrLf
indekser2 = indekser2 + 1
Next komorka
tekst1 = tekst1 & vbCrLf & "Cells count: " & CStr(liczbaKomorek1)
tekst2 = tekst2 & vbCrLf & "Cells count: " & CStr(liczbaKomorek2)
MsgBox tekst1
MsgBox tekst2
End Sub
我的问题是,当用户在 Word 表格中选择非矩形区域时,如何获得有效的选定单元格集合?
最佳答案
感谢 Tim Williams 发表的文章,我设法找到了解决方案。这个解决方案绝不是完美的,但它提供了而且我没有设法想到更好的东西。为了获得所选单元格的有效集合,当表格中有连续选择时。我们可以更改连续选择支持的属性之一。之后我们可以很容易地找到具有更改属性的单元格,这些单元格将是表格中所有选定的单元格。这是我创建的方法,我使用 Font.Size 来查找选定的单元格:
public static List<System.Drawing.Point> GetSelectedCells()
{
//We will use this to hold column and row coordinates for cells
List<System.Drawing.Point> value = new List<System.Drawing.Point>();
try
{
Microsoft.Office.Interop.Word.Range range = Globals.ThisAddIn.Application.Selection.Range;
if (range.Tables.Count > 0)
{
Table tempTable = range.Tables[1];
float[,] backupTable = new float[range.Tables[1].Rows.Count + 1, range.Tables[1].Columns.Count + 1];
for (int i = 1; i <= tempTable.Rows.Count; i++)
{
for (int j = 1; j <= tempTable.Rows[i].Cells.Count; j++)
backupTable[i, j] = tempTable.Rows[i].Cells[j].Range.Font.Size;
}
Globals.ThisAddIn.Application.Selection.Font.Size = 1;
foreach (Row row in range.Tables[1].Rows)
{
foreach (Cell cell in row.Cells)
{
if (cell.Range.Font.Size == 1)
{
System.Drawing.Point point = new System.Drawing.Point();
point.X = cell.RowIndex;
point.Y = cell.ColumnIndex;
value.Add(point);
}
}
}
for (int i = 1; i <= tempTable.Rows.Count; i++)
{
for (int j = 1; j <= tempTable.Rows[i].Cells.Count; j++)
tempTable.Rows[i].Cells[j].Range.Font.Size = backupTable[i, j];
}
Marshal.ReleaseComObject(tempTable);
}
}
catch(Exception)
{
//This exception can be used to handle Exception that occurs when there are merged cells in the table.
}
return value;
}
这不适用于合并的单元格。
关于c# - Word 互操作 : How to obtain valid selected cells collection from Word table when selection area is not a rectangle?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22666219/
当我尝试输入时,我正在关注 Ray Wenderlich ( https://videos.raywenderlich.com/screencasts/545-server-side-swift-wi
我正在使用 javax.validation.Validation 来验证 jpa 实体。我总是针对相同的实体进行验证。 我想知道是对所有验证使用一个 validator 更好,还是每次验证时实例化一
Controller : @RequestMapping(...) public void foo(@Valid Parent p){ } class Parent { @NotNull // j
在 login.phtml 中,validator 和 validate 之间有什么区别 - 有人可以解释下面每一行的含义 function onepageLogin(button)
我有一个 java bean 用于将 JSON 消息发送到 spring @RestController 并且我有 bean 验证设置并使用 @Valid 运行得很好。但我想转移到 Protobuf/
我正在使用 vee-validate 来验证注册表单,我编写了如下代码,
使用 有什么区别属性和 标签? 我应该什么时候使用哪一种? 最佳答案 validator属性允许您引用独立的托管 bean 方法,而不仅仅是像这样的验证器
我们有这个 Alamofire 错误处理: Alamofire.request(.GET, getUrl("mystuff")).responseData { response in guar
以下代码创建了两个单选按钮。每个选项都包含一个日期值,该日期值已成功转换为格式为“yyyy-MM-dd”的标签。一旦我做出选择并单击下一步按钮,我就会收到以下错误“j_idt12:comDateCho
是否有类似的验证: req.checkBody('property', 'should be present').isPresent(); 值本身并不重要。 现在我使用这个解决方案: .isLengt
系列文章: 1、async-validator 源码学习(一):文档翻译 2、async-validator 源码学习笔记(二):目录结构 3、async-validator 源码学习笔记(三):ru
我正在使用 Backbone.Validation插入。我有一个模型可以在服务器端进行唯一性检查。我如何让 backbone.validation 识别错误并运行我设置的回调以显示返回的错误消息? t
我有一个 Knockout.Validation 场景,我认为该场景相当普遍,但尚未通过在网络上搜索和本网站上的各种答案找到解决方案。 我正在验证的属性在 ajax 调用之后才会添加到可观察到的 kn
我是 Knockout JS 的新手。我需要一个验证器来验证用户将在文本框中输入的日期。为此编写了如下代码 ko.validation.rules['date'] = { validator:
如何在 JSF 验证器中比较两个字符串是否相等? if (!settingsBean.getNewPassword().equals(settingsBean.getConfirmPassword()
我有简单的域: package app class Customers { String CUSTOMER String NOTE static mapping = {
我正在使用 ember-validations 来验证表单中的模型。 如果我使用 createRecord 创建记录,则模型的实例已经过验证,因此在用户输入值之前表单已经显示验证错误。 我只想在提交表
我有两种不同的服务:第一个是将对象保存到数据库,第二个是更新现有对象。 我正在对我的对象使用验证约束,例如(@NotBlank、@Size、@Pattern 等),在第一种情况下,我需要验证对象的所有
我有 2 个 ensure - 验证装饰器用于 2 个字段:password 和 retypePassword。我想在填写 retypePassword 字段时检查这两个字段是否相等。 问题是,当我在
I'm aware that it's a bug ,但是在域类上调用 validate() 会覆盖之前放入的任何拒绝: def save = { def assignment = new A
我是一名优秀的程序员,十分优秀!