Excel.Workbook class

Workbook 是包含相关工作簿对象(例如工作表、表和区域)的顶级对象。 若要了解有关工作簿对象模型的详细信息,请阅读 使用 Excel JavaScript API 处理工作簿。

扩展

注解

[ API 集:ExcelApi 1.1 ]

属性

application

表示包含此工作簿的 Excel 应用程序实例。

bindings

表示属于工作簿的绑定的集合。

context

与 对象关联的请求上下文。 这会将加载项的进程连接到 Office 主机应用程序的进程。

customXmlParts

表示此工作簿包含的自定义 XML 部件的集合。

dataConnections

表示工作簿中的所有数据连接。

functions

表示可用于计算的工作表函数的集合。

name

获取工作簿名称。

names

表示工作簿范围的命名项的集合, () 命名区域和常量。

pivotTables

表示一组与 workbook 相关联的 PivotTable 对象。

properties

获取工作簿属性。

protection

返回工作簿的保护对象。

settings

表示与工作簿关联的设置的集合。

styles

表示与工作簿关联的样式的集合。

tables

表示与工作簿关联的表的集合。

worksheets

表示与工作簿关联的工作表的集合。

方法

getActiveCell()

获取工作簿中当前处于活动状态的单元格。

getSelectedRange()

从工作簿中获取当前选定的单个区域。 如果选择了多个范围,此方法将引发错误。

load(options)

将命令加入队列以加载对象的指定属性。 阅读属性前必须先调用 context.sync()

load(propertyNames)

将命令加入队列以加载对象的指定属性。 阅读属性前必须先调用 context.sync()

load(propertyNamesAndPaths)

将命令加入队列以加载对象的指定属性。 阅读属性前必须先调用 context.sync()

set(properties, options)

同时设置对象的多个属性。 可以传递具有相应属性的纯对象,也可以传递同一类型的另一个 API 对象。

set(properties)

基于现有的已加载对象,同时对对象设置多个属性。

toJSON()

重写 JavaScript toJSON() 方法,以便在将 API 对象传递给 JSON.stringify()时提供更有用的输出。 JSON.stringify (,依次调用toJSON传递给它的 对象的 方法。) 虽然原始Excel.Workbook对象是 API 对象,toJSON但该方法返回一个纯 JavaScript 对象, (类型为 Excel.Interfaces.WorkbookData) ,其中包含从原始对象加载的任何子属性的浅表副本。

事件

onSelectionChanged

文档中的选择更改时发生。

属性详细信息

application

表示包含此工作簿的 Excel 应用程序实例。

readonly application: Excel.Application;

属性值

注解

[ API 集:ExcelApi 1.1 ]

bindings

表示属于工作簿的绑定的集合。

readonly bindings: Excel.BindingCollection;

属性值

注解

[ API 集:ExcelApi 1.1 ]

context

与 对象关联的请求上下文。 这会将加载项的进程连接到 Office 主机应用程序的进程。

context: RequestContext;

属性值

customXmlParts

表示此工作簿包含的自定义 XML 部件的集合。

readonly customXmlParts: Excel.CustomXmlPartCollection;

属性值

注解

[ API 集:ExcelApi 1.5 ]

dataConnections

表示工作簿中的所有数据连接。

readonly dataConnections: Excel.DataConnectionCollection;

属性值

注解

[ API 集:ExcelApi 1.7 ]

functions

表示可用于计算的工作表函数的集合。

readonly functions: Excel.Functions;

属性值

注解

[ API 集:ExcelApi 1.2 ]

name

获取工作簿名称。

readonly name: string;

属性值

string

注解

[ API 集:ExcelApi 1.7 ]

names

表示工作簿范围的命名项的集合, () 命名区域和常量。

readonly names: Excel.NamedItemCollection;

属性值

注解

[ API 集:ExcelApi 1.1 ]

pivotTables

表示一组与 workbook 相关联的 PivotTable 对象。

readonly pivotTables: Excel.PivotTableCollection;

属性值

注解

[ API 集:ExcelApi 1.3 ]

示例

// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/excel/38-pivottable/pivottable-get-pivottables.yaml

await Excel.run(async (context) => {
  // Get the names of all the PivotTables in the workbook.
  const pivotTables = context.workbook.pivotTables;
  pivotTables.load("name");
  await context.sync();

  // Display the names in the console.
  console.log("PivotTables in the workbook:")
  pivotTables.items.forEach((pivotTable) => {
    console.log(`\t${pivotTable.name}`);
  });
});

properties

获取工作簿属性。

readonly properties: Excel.DocumentProperties;

属性值

注解

[ API 集:ExcelApi 1.7 ]

示例

// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/excel/26-document/properties.yaml

await Excel.run(async (context) => {
    let titleValue = "Excel document properties API";
    let subjectValue = "Set and get document properties";
    let keywordsValue = "Set and get operations";
    let commentsValue = "This is an Excel document properties API code sample";
    let categoryValue = "Office Add-ins";
    let managerValue = "John";
    let companyValue = "Microsoft";

    let docProperties = context.workbook.properties;

    // Set the writeable document properties.
    docProperties.title = titleValue;
    docProperties.subject = subjectValue;
    docProperties.keywords = keywordsValue;
    docProperties.comments = commentsValue;
    docProperties.category = categoryValue;
    docProperties.manager = managerValue;
    docProperties.company = companyValue;

    await context.sync();

    console.log("Set the following document properties: title, subject, keywords, comments, category, manager, company.");
});

protection

返回工作簿的保护对象。

readonly protection: Excel.WorkbookProtection;

属性值

注解

[ API 集:ExcelApi 1.7 ]

settings

表示与工作簿关联的设置的集合。

readonly settings: Excel.SettingCollection;

属性值

注解

[ API 集:ExcelApi 1.4 ]

styles

表示与工作簿关联的样式的集合。

readonly styles: Excel.StyleCollection;

属性值

注解

[ API 集:ExcelApi 1.7 ]

示例

// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/excel/42-range/style.yaml

await Excel.run(async (context) => {
    let styles = context.workbook.styles;

    // Add a new style to the style collection.
    // Styles is in the Home tab ribbon.
    styles.add("Diagonal Orientation Style");
          
    let newStyle = styles.getItem("Diagonal Orientation Style");
    
    // The "Diagonal Orientation Style" properties.
    newStyle.textOrientation = 38;
    newStyle.autoIndent = true;
    newStyle.includeProtection = true;
    newStyle.shrinkToFit = true;
    newStyle.locked = false;
    
    await context.sync();

    console.log("Successfully added a new style with diagonal orientation to the Home tab ribbon.");
});

tables

表示与工作簿关联的表的集合。

readonly tables: Excel.TableCollection;

属性值

注解

[ API 集:ExcelApi 1.1 ]

worksheets

表示与工作簿关联的工作表的集合。

readonly worksheets: Excel.WorksheetCollection;

属性值

注解

[ API 集:ExcelApi 1.1 ]

方法详细信息

getActiveCell()

获取工作簿中当前处于活动状态的单元格。

getActiveCell(): Excel.Range;

返回

注解

[ API 集:ExcelApi 1.7 ]

示例

// Link to full sample: https://raw.githubusercontent.com/OfficeDev/office-js-snippets/prod/samples/excel/50-workbook/workbook-get-active-cell.yaml

await Excel.run(async (context) => {

    let myWorkbook = context.workbook;
    let activeCell = myWorkbook.getActiveCell();
    activeCell.load("address");

    await context.sync();
    
    console.log("The active cell is " + activeCell.address);
});

getSelectedRange()

从工作簿中获取当前选定的单个区域。 如果选择了多个范围,此方法将引发错误。

getSelectedRange(): Excel.Range;

返回

注解

[ API 集:ExcelApi 1.1 ]

示例

await Excel.run(async (context) => { 
    const selectedRange = context.workbook.getSelectedRange();
    selectedRange.load('address');
    await context.sync();
    console.log(selectedRange.address);
});

load(options)

将命令加入队列以加载对象的指定属性。 阅读属性前必须先调用 context.sync()

load(options?: Excel.Interfaces.WorkbookLoadOptions): Excel.Workbook;

参数

options
Excel.Interfaces.WorkbookLoadOptions

提供要加载对象的属性的选项。

返回

load(propertyNames)

将命令加入队列以加载对象的指定属性。 阅读属性前必须先调用 context.sync()

load(propertyNames?: string | string[]): Excel.Workbook;

参数

propertyNames

string | string[]

逗号分隔的字符串或指定要加载的属性的字符串数组。

返回

load(propertyNamesAndPaths)

将命令加入队列以加载对象的指定属性。 阅读属性前必须先调用 context.sync()

load(propertyNamesAndPaths?: {
            select?: string;
            expand?: string;
        }): Excel.Workbook;

参数

propertyNamesAndPaths

{ select?: string; expand?: string; }

propertyNamesAndPaths.select 是一个逗号分隔的字符串,指定要加载的属性,是 propertyNamesAndPaths.expand 一个逗号分隔的字符串,指定要加载的导航属性。

返回

set(properties, options)

同时设置对象的多个属性。 可以传递具有相应属性的纯对象,也可以传递同一类型的另一个 API 对象。

set(properties: Interfaces.WorkbookUpdateData, options?: OfficeExtension.UpdateOptions): void;

参数

properties
Excel.Interfaces.WorkbookUpdateData

一个 JavaScript 对象,其属性按同构方式构造为调用方法的对象的属性。

options
OfficeExtension.UpdateOptions

提供一个选项,用于在 properties 对象尝试设置任何只读属性时禁止显示错误。

返回

void

set(properties)

基于现有的已加载对象,同时对对象设置多个属性。

set(properties: Excel.Workbook): void;

参数

properties
Excel.Workbook

返回

void

toJSON()

重写 JavaScript toJSON() 方法,以便在将 API 对象传递给 JSON.stringify()时提供更有用的输出。 JSON.stringify (,依次调用toJSON传递给它的 对象的 方法。) 虽然原始Excel.Workbook对象是 API 对象,toJSON但该方法返回一个纯 JavaScript 对象, (类型为 Excel.Interfaces.WorkbookData) ,其中包含从原始对象加载的任何子属性的浅表副本。

toJSON(): Excel.Interfaces.WorkbookData;

返回

事件详细信息

onSelectionChanged

文档中的选择更改时发生。

readonly onSelectionChanged: OfficeExtension.EventHandlers<Excel.SelectionChangedEventArgs>;

事件类型

注解

[ API 集:ExcelApi 1.2 ]