GetAncestor
内容
[
隐藏
]GetAncestor(Type)
获取指定对象类型的第一个祖先。
public CompositeNode GetAncestor(Type ancestorType)
| 范围 | 类型 | 描述 | 
|---|---|---|
| ancestorType | Type | 要检索的祖先的对象类型。 | 
返回值
指定类型的祖先或无效的如果没有找到此类型的祖先。
评论
如果祖先类型等于ancestorType或源自ancestorType。
例子
显示如何确定表是否嵌套。
public void CalculateDepthOfNestedTables()
{
    Document doc = new Document(MyDir + "Nested tables.docx");
    NodeCollection tables = doc.GetChildNodes(NodeType.Table, true);
    for (int i = 0; i < tables.Count; i++)
    {
        Table table = (Table)tables[i];
        // 查明表格中是否有单元格具有其他表格作为子表格。
        int count = GetChildTableCount(table);
        Console.WriteLine("Table #{0} has {1} tables directly within its cells", i, count);
        // 查明表是否嵌套在另一个表中,如果是,则嵌套深度是多少。
        int tableDepth = GetNestedDepthOfTable(table);
        if (tableDepth > 0)
            Console.WriteLine("Table #{0} is nested inside another table at depth of {1}", i,
                tableDepth);
        else
            Console.WriteLine("Table #{0} is a non nested table (is not a child of another table)", i);
    }
}
/// <summary>
/// 计算一个表嵌套在其他表中的级别。
/// </summary>
/// <returns>
/// 一个整数,表示表的嵌套深度(父表节点的数量)。
/// </returns>
private static int GetNestedDepthOfTable(Table table)
{
    int depth = 0;
    Node parent = table.GetAncestor(table.NodeType);
    while (parent != null)
    {
        depth++;
        parent = parent.GetAncestor(typeof(Table));
    }
    return depth;
}
/// <summary>
/// 确定表的单元格内是否包含任何直接子表。
/// 不要递归遍历这些表来检查进一步的表。
/// </summary>
/// <returns>
/// 如果至少有一个子单元格包含表格,则返回 true。
/// 如果表格中没有单元格包含表格,则返回 false。
/// </returns>
private static int GetChildTableCount(Table table)
{
    int childTableCount = 0;
    foreach (Row row in table.Rows)
    {
        foreach (Cell Cell in row.Cells)
        {
            TableCollection childTables = Cell.Tables;
            if (childTables.Count > 0)
                childTableCount++;
        }
    }
    return childTableCount;
}
也可以看看
- class CompositeNode
- class Node
- 命名空间 Aspose.Words
- 部件 Aspose.Words
GetAncestor(NodeType)
获取指定的第一个祖先NodeType.
public CompositeNode GetAncestor(NodeType ancestorType)
| 范围 | 类型 | 描述 | 
|---|---|---|
| ancestorType | NodeType | 要检索的祖先节点类型。 | 
返回值
指定类型的祖先或无效的如果没有找到此类型的祖先。
例子
显示如何确定表是否嵌套。
public void CalculateDepthOfNestedTables()
{
    Document doc = new Document(MyDir + "Nested tables.docx");
    NodeCollection tables = doc.GetChildNodes(NodeType.Table, true);
    for (int i = 0; i < tables.Count; i++)
    {
        Table table = (Table)tables[i];
        // 查明表格中是否有单元格具有其他表格作为子表格。
        int count = GetChildTableCount(table);
        Console.WriteLine("Table #{0} has {1} tables directly within its cells", i, count);
        // 查明表是否嵌套在另一个表中,如果是,则嵌套深度是多少。
        int tableDepth = GetNestedDepthOfTable(table);
        if (tableDepth > 0)
            Console.WriteLine("Table #{0} is nested inside another table at depth of {1}", i,
                tableDepth);
        else
            Console.WriteLine("Table #{0} is a non nested table (is not a child of another table)", i);
    }
}
/// <summary>
/// 计算一个表嵌套在其他表中的级别。
/// </summary>
/// <returns>
/// 一个整数,表示表的嵌套深度(父表节点的数量)。
/// </returns>
private static int GetNestedDepthOfTable(Table table)
{
    int depth = 0;
    Node parent = table.GetAncestor(table.NodeType);
    while (parent != null)
    {
        depth++;
        parent = parent.GetAncestor(typeof(Table));
    }
    return depth;
}
/// <summary>
/// 确定表的单元格内是否包含任何直接子表。
/// 不要递归遍历这些表来检查进一步的表。
/// </summary>
/// <returns>
/// 如果至少有一个子单元格包含表格,则返回 true。
/// 如果表格中没有单元格包含表格,则返回 false。
/// </returns>
private static int GetChildTableCount(Table table)
{
    int childTableCount = 0;
    foreach (Row row in table.Rows)
    {
        foreach (Cell Cell in row.Cells)
        {
            TableCollection childTables = Cell.Tables;
            if (childTables.Count > 0)
                childTableCount++;
        }
    }
    return childTableCount;
}
也可以看看
- class CompositeNode
- enum NodeType
- class Node
- 命名空间 Aspose.Words
- 部件 Aspose.Words