Filtering user interface for a data summary table

Information

  • Patent Grant
  • 9959267
  • Patent Number
    9,959,267
  • Date Filed
    Monday, December 28, 2015
    9 years ago
  • Date Issued
    Tuesday, May 1, 2018
    6 years ago
Abstract
A graphical user interface for creating a data summary table includes a data summary table including a plurality of fields, and a filtering pane programmed to apply filters to items in the fields of the data summary table, the filtering pane including a field selector control, wherein the field selector control is programmed to allow for selection of a field of the fields in the data summary table to define filtering for the field.
Description
BACKGROUND

Data summary tables can be used to analyze large amounts of data. One example of a data summary table is PIVOTTABLE dynamic views that can be generated using Microsoft Corporation's EXCEL spreadsheet software. A data summary table provides an efficient way to display and summarize data that is supplied by a database program or that is in a data listing of a spreadsheet. A user can select fields of the data to include within page, row, column, or data regions of the data summary table and can choose parameters such as the sum, variance, count, and standard deviation to be displayed for selected data fields. Data in a database that can be queried from within a spreadsheet program, or spreadsheet data including lists, can be analyzed in a data summary table.


Although a data summary table is designed so that data can be efficiently and intuitively analyzed, creation of the data summary table itself can be challenging for novice users. For example, some programs provide wizards that assist the user in creating a data summary table. While these wizards may be helpful in creating an initial data summary table, the wizards cannot easily be used to modify the display once it is created. Other programs allow users to drag and drop desired fields directly onto the data summary table. While these programs provide the user with greater flexibility when creating the display, such programs can be less intuitive for a novice to use.


SUMMARY

This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.


According to one aspect, a graphical user interface for creating a data summary table includes a data summary table including a plurality of fields, and a filtering pane programmed to apply filters to items in the fields of the data summary table, the filtering pane including a field selector control, wherein the field selector control is programmed to allow for selection of a field of the fields in the data summary table to define filtering for the field.


According to another aspect, in a computer system having a graphical user interface for a data summary table, a method includes: allowing selection of a field from a plurality of fields; presenting filtering options for the field; associating selected filtering with the field; and thereafter, applying the selected filtering to items in the field when the field is added to a data summary table.


According to another aspect, a computer-readable medium has computer-executable instructions for performing steps including: allowing selection of a field from a plurality of fields; presenting filtering options for the field; associating selected filtering with the field; and thereafter, applying the selected filtering to items in the field when the field is added to a data summary table.





BRIEF DESCRIPTION OF THE DRAWINGS

Reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:



FIG. 1 illustrates an example general purpose computing system;



FIG. 2 illustrates an example sheet of a spreadsheet program;



FIG. 3 illustrates an example data summary table and task pane of the spreadsheet program;



FIG. 4 illustrates the example task pane of FIG. 3;



FIG. 5 illustrates another example task pane;



FIG. 6 illustrates an example menu for replacement of a field in a layout pane of a task pane;



FIG. 7 illustrates an example method for placement of a field in a layout pane of the task pane of FIG. 4;



FIG. 8 illustrates the example data summary table and task pane of FIG. 3 with a field added to the table;



FIG. 9 illustrates the example data summary table and task pane of FIG. 3 with multiple fields added to the table;



FIG. 10 illustrates the example data summary table and task pane of FIG. 9 with a field rearranged on the table;



FIG. 11 illustrates another example task pane;



FIG. 12 illustrates an example menu for modifying a layout of the task pane of FIG. 11;



FIG. 13 illustrates the example task pane of FIG. 11 in a different layout;



FIG. 14 illustrates the example task pane of FIG. 11 in a different layout;



FIG. 15 illustrates the example task pane of FIG. 11 in a different layout;



FIG. 16 illustrates the example task pane of FIG. 11 in a different layout;



FIG. 17 illustrates an example method for placement of a field in a layout pane of the task pane of FIG. 4;



FIG. 18 illustrates another example method for placement of a field in a layout pane of the task pane of FIG. 4;



FIG. 19 illustrates another example method for placement of a field in a layout pane of the task pane of FIG. 4;



FIG. 20 illustrates an example filtering task pane;



FIG. 21 illustrates an example manual filter area for another filtering task pane;



FIG. 22 illustrates an example fly-out menu for the filtering task pane of FIG. 20;



FIG. 23 illustrates another example fly-out menu for the filtering task pane of FIG. 20;



FIG. 24 illustrates an example dialog box for the filtering task pane of FIG. 20;



FIG. 25 illustrates another example filtering task pane;



FIG. 26 illustrates an example fly-out menu for the filtering task pane of FIG. 25;



FIG. 27 illustrates another example task pane;



FIG. 28 illustrates an example tool-tip for the task pane of FIG. 27.





DETAILED DESCRIPTION

Embodiments will now be described more fully hereinafter with reference to the accompanying drawings. Embodiments disclosed herein are examples and should not be construed as limiting; rather, these embodiments are provided so that this disclosure will be thorough and complete. Like numbers refer to like elements throughout.


Embodiments described herein relate to data summary tables used to analyze data on a computer system.


Referring now to FIG. 1, an example computer system 100 is illustrated. The computer system 100 illustrated in FIG. 1 can take a variety of forms such as, for example, a desktop computer, a laptop computer, and a hand-held computer. In addition, although computer system 100 is illustrated, the systems and methods disclosed herein can be implemented in various alternative computer systems as well.


The system 100 includes a processor unit 102, a system memory 104, and a system bus 106 that couples various system components including the system memory 104 to the processor unit 102. The system bus 106 can be any of several types of bus structures including a memory bus, a peripheral bus and a local bus using any of a variety of bus architectures. The system memory includes read only memory (ROM) 108 and random access memory (RAM) 110. A basic input/output system 112 (BIOS), which contains basic routines that help transfer information between elements within the computer system 100, is stored in ROM 108.


The computer system 100 further includes a hard disk drive 112 for reading from and writing to a hard disk, a magnetic disk drive 114 for reading from or writing to a removable magnetic disk 116, and an optical disk drive 118 for reading from or writing to a removable optical disk 119 such as a CD ROM, DVD, or other optical media. The hard disk drive 112, magnetic disk drive 114, and optical disk drive 118 are connected to the system bus 106 by a hard disk drive interface 120, a magnetic disk drive interface 122, and an optical drive interface 124, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer readable instructions, data structures, programs, and other data for the computer system 100.


Although the example environment described herein can employ a hard disk 112, a removable magnetic disk 116, and a removable optical disk 119, other types of computer-readable media capable of storing data can be used in the example system 100. Examples of these other types of computer-readable mediums that can be used in the example operating environment include magnetic cassettes, flash memory cards, digital video disks, Bernoulli cartridges, random access memories (RAMs), and read only memories (ROMs).


A number of program modules can be stored on the hard disk 112, magnetic disk 116, optical disk 119, ROM 108, or RAM 110, including an operating system 126, one or more application programs 128, other program modules 130, and program data 132.


A user may enter commands and information into the computer system 100 through input devices such as, for example, a keyboard 134, mouse 136, or other pointing device. Examples of other input devices include a toolbar, menu, touch screen, microphone, joystick, game pad, pen, satellite dish, and scanner. These and other input devices are often connected to the processing unit 102 through a serial port interface 140 that is coupled to the system bus 106. Nevertheless, these input devices also may be connected by other interfaces, such as a parallel port, game port, or a universal serial bus (USB). An LCD display 142 or other type of display device is also connected to the system bus 106 via an interface, such as a video adapter 144. In addition to the display 142, computer systems can typically include other peripheral output devices (not shown), such as speakers and printers.


The computer system 100 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 146. The remote computer 146 may be a computer system, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer system 100. The network connections include a local area network (LAN) 148 and a wide area network (WAN) 150. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and the Internet.


When used in a LAN networking environment, the computer system 100 is connected to the local network 148 through a network interface or adapter 152. When used in a WAN networking environment, the computer system 100 typically includes a modem 154 or other means for establishing communications over the wide area network 150, such as the Internet. The modem 154, which can be internal or external, is connected to the system bus 106 via the serial port interface 140. In a networked environment, program modules depicted relative to the computer system 100, or portions thereof, may be stored in the remote memory storage device. It will be appreciated that the network connections shown are examples and other means of establishing a communications link between the computers may be used.


The embodiments described herein can be implemented as logical operations in a computing system. The logical operations can be implemented (1) as a sequence of computer implemented steps or program modules running on a computer system and (2) as interconnected logic or hardware modules running within the computing system. This implementation is a matter of choice dependent on the performance requirements of the specific computing system. Accordingly, the logical operations making up the embodiments described herein are referred to as operations, steps, or modules. It will be recognized by one of ordinary skill in the art that these operations, steps, and modules may be implemented in software, in firmware, in special purpose digital logic, and any combination thereof without deviating from the spirit and scope of the present invention as recited within the claims attached hereto. This software, firmware, or similar sequence of computer instructions may be encoded and stored upon computer readable storage medium and may also be encoded within a carrier-wave signal for transmission between computing devices.


Referring now to FIG. 2, an example program 200 is shown. In one example, program 200 is Microsoft's EXCEL spreadsheet software program running on a computer system, such as computer system 100 described above. Program 200 includes a spreadsheet 205 with an example list of data 210. A user can create a data summary table from data 210.


For example, referring now to FIG. 3, an example user interface 302 of program 200 is shown. User interface 302 includes an initial data summary table 320 (data summary table 320 is blank in FIG. 3). Data summary table 320 can be created from data from various sources. In one example as shown in FIG. 3, data summary table 320 can be created from data from one or more databases, as described further below. In other embodiments, data summary table 320 can be created from data in a spreadsheet, such as data 210 shown in FIG. 2.


User interface 302 of program 200 also includes an example task pane 450 that can be used to create and modify data summary table 320. For example, task pane 450 includes a list of the fields from data 210. The user can select and deselect fields from task pane 450 to create data summary table 320, as described further below.


I. Task Pane


Referring now to FIG. 4, example task pane 450 is shown. Task pane 450 generally includes a field pane 452 and a layout pane 454. Task pane 450 is used to create and modify data summary table 320, as described further below.


Field pane 452 includes a list 453 of each field in a given database or spreadsheet (e.g., spreadsheet 205 as shown in FIG. 2 above). A scroll bar 451 is provided because the list 453 of fields is longer than the space provided by field pane 452. In some embodiments, field pane 452 (and layout pane 454 as well) can be resized by the user. Each field in list 453 includes a checkbox next to the field. For example, the field “Profit” includes a checkbox 460 positioned adjacent to the field caption. When a field in list 453 is added to layout pane 454 as described below, the checkbox associated with the field is checked. For example, checkbox 460 for the “Profit” field is checked because it has been added to layout pane 454.


Layout pane 454 includes a plurality of zones that represent aspects of the data summary table 320 that is created using task pane 450. For example, layout pane 454 includes a row zone 455, a column zone 456, a value zone 457, and a filter zone 458. Row zone 455 defines the row labels for the resulting data summary table 320. Column zone 456 defines the column labels for data summary table 320. Value zone 457 identifies the data that is summarized (e.g., aggregation, variation, etc.) on data summary table 320. Filter zone 458 allows for the selection of filtering that is applied to all other fields in the other zones 455, 456, 457 (e.g., a field can be placed in filter zone 458 and one or more items associated with the field can be selected to create a filter to show only those items for all other fields in layout pane 454 that are associated with the item(s) selected for the field in filter zone 458).


One or more of the fields from field pane 452 are added to one or more of the zones of layout pane 454 to create and modify data summary table 320. In the example shown, the user can click, drag, and drop a field from list 453 of field pane 452 to one of the zones of layout pane 454 to add a field to the data summary table 320.


For example, as shown in FIG. 5, the user can hover over a particular field included in field pane 452, such as the “Store Sales” field 466. As the user hovers over the field, the user is presented with a cross-hair cursor 472 that indicates that the user can click and drag the selected field from the field pane 452 to one of the zones of the layout pane 454. Once the user selects the field, the cross-hair cursor 472 returns to a normal cursor, and the “Store Sales” field 466 can be dragged and dropped into the value zone 457, as shown. A field can similarly be removed from layout pane 454 by selecting and dragging the field out of layout pane 454.


In another example, the user can check the checkbox associated with a particular field in field pane 452 to add the field to layout pane 454. For example, if the user selects checkbox 460 associated with the “Profit” field shown in task pane 450 of FIG. 4, this field can be added to value zone 457 as “Profit” field 462. As described further below, program 200 can be programmed to analyze and place the selected field in an appropriate zone of layout pane 454. The user can similarly unselect a checked field to remove the field from layout pane 454. For example, if the user unselects checkbox 460, the “Profit” field 462 is removed from layout pane 454.


In an optional example, if a user clicks on a given field to select the field without dragging the field to one of the zones of drop zone 454, the user can be presented with a menu (e.g., similar to that of menu 482 shown in FIG. 6) that allows the user to select which zone to place the field.


Referring now to FIG. 7, an example method 500 for adding a field from field pane 452 to a zone of layout pane 454 is shown. At operation 501, the user selects a field listed in field pane 452 to add to layout pane 454. At operation 502, a determination is made regarding whether the user selected the checkbox associated with the particular field. If the user selected the checkbox, control is passed to operation 503, and program 200 can automatically determine which zone of layout pane 454 to place the selected field. Next, in operation 507, the field is added to the appropriate zone of layout pane 454.


If a determination is made at operation 502 that the user has not selected the checkbox, control is passed to operation 504. At operation 504, a determination is made regarding whether the user has selected, dragged, and dropped the field into one of the zones of layout pane 454. If the user has dropped the field into one of the zones of layout pane 454, control is passed to operation 507, and the field is added to the zone.


If a determination is made at operation 504 that the user has not dragged and dropped the field, in an optional embodiment control is passed to operation 505 because the user has selected the field without selecting the checkbox or dragging/dropping the field into a zone of the layout pane 454. At operation 505, program 200 presents the user with a menu to allow the user to select the zone to which to add the field. Next, at operation 506, the user selects the desired zone. At operation 507, the field is added to the zone.


Once the field has been added to the zone of layout pane 454, control is passed to operation 509, and program 200 updates the data summary table 320 accordingly, as described below.


Referring again to FIG. 4, once a field such as the “Profit” field from the field pane 452 is added to one of the zones of layout pane 454, the checkbox (e.g., checkbox 460) associated with that field in field pane 452 is checked to indicate that the field is part of data summary table 320. In addition, the font of the field label associated with the field in field pane 452 is bolded. Similarly, when a field has not yet been made part of data summary table 320 (or has been removed therefrom), the checkbox associated with the field is left unchecked and the field is shown in normal, rather than bold, font. Others methods for indicating the fields that are part of data summary table 320 can also be used.


As fields are added and removed from layout pane 454 of task pane 450, the resulting data summary table 320 is modified accordingly. For example, the user is initially presented with task pane 450 including field pane 452 as shown in FIG. 3. Referring to FIG. 8, when the user adds the “Profit” field to value zone 457 of layout pane 454, a sum of the data associated with the “Profit” field is automatically added to data summary table 320. Referring to FIG. 9, the user can add additional fields (e.g., “Sales Average,” “Customers,” “Gender”) to zones of layout pane 454, and data summary table 320 is updated to include data related to the added fields.


Referring to FIG. 10, the user can also move fields from one zone to another zone in layout pane 454 of task pane 450, and data summary table 320 is updated accordingly. For example, the user can move the “Gender” field from column zone 456 to row zone 455, and data summary table 320 is automatically updated accordingly to reflect the change. The user can also move fields within a given zone 455, 456, 457, 458 to change the order in which the fields are displayed in data summary table 320. For example, the user can move the “Gender” field above the “Customer” field in row zone 455 so that the “Gender” field is shown prior to the “Customer” field in data summary table 320.


Referring now to FIG. 6, in one example if the user clicks and releases a field such as “Product Categories” field 481 located in layout pane 454 without dragging the field, the user is presented with a menu 482 that allows the user to manipulate the placement of the field within layout pane 454. For example, menu 482 allows the user to change the position of the field within a given zone (i.e., “Move Up,” “Move Down,” “Move to Beginning,” “Move to End”), move the field between zones (i.e., “Move to Row Labels,” “Move to Values,” “Move to Column Labels,” “Move to Report Filter”), and remove the field from layout pane 454 (i.e., “Remove Field”). Only those options that are available for a particular field are shown as active choices in menu 482 (e.g., “Move to Row Labels” is shown as inactive in the example because field 481 is already in row zone 455).


Referring again to FIG. 4, task pane 450 also includes a manual update checkbox 469. When checkbox 469 is selected, the resulting data summary table 320 is not automatically updated as fields are added, rearranged, and removed from layout pane 454 of task pane 450. For example, if the user selects manual update checkbox 469 and then adds a field to row zone 455 of layout pane 454, data summary table 320 is not automatically updated to reflect the newly added field. Instead, update occurs after the user selects a manual update button 471 that becomes active once a change has been made and a manual update can be performed. Manual updates can be used to increase efficiency when working with large amounts of data that require significant retrieval and processing time to create the data summary table 320. In this manner, the desired fields and filtering can be selected prior to creation or revision of the data summary table 320, which occurs upon selection of the manual update button 471, thereby enhancing efficiency.


Referring to FIG. 11, the fields shown in field pane 452 represent data fields of the “online analysis processing” (OLAP) type. (In contrast, the fields shown in field pane 452 in FIG. 5 are of non-OLAP type, sometime referred to as relational fields.) OLAP is a category of tools that provides analysis of data stored in a database. OLAP tools allow users to analyze different dimensions of multidimensional data. OLAP data fields are arranged in a hierarchical structure with a plurality of levels. For example, the “Sales Fact 1991” field includes sub-fields “Store Sales,” “Unit Sales,” and “Store Cost.” Sub-fields can be accessed by clicking on the drill indicator (plus/minus+/−sign) 556 to expand and collapse the sub-fields. OLAP data can be arranged into dimensions with hierarchies and measures.


In the embodiment shown, each field listed in field pane 452 includes a plurality of components. A field can be highlighted by hovering over or clicking the field. For example, each field, such as the “Product” field shown in FIG. 11 includes selection areas 558 and 559 that allow a user to select and drag the field. Each field also includes checkbox 560 that can be used to add/remove the field from data summary table 320. In addition, each field of OLAP data type can include drill indicator 556 that is used to expand and collapse the sub-fields associated with the field. In addition, each field includes a drop down area 562 used to access filtering options, as described further below.


Referring again to FIG. 4, task pane 450 also includes a control 470 that allows the user to modify the layout of task pane 450. For example, the user can select control 470 to access a layout menu 572, as shown in FIG. 12. Layout menu 572 is used to arrange panes 452 and 454. For example, if the user selects “Fields and Layout stacked” 573 in control 470, field pane 452 is positioned above layout pane 454 in task pane 450 to form a single integrated pane, as shown in FIG. 4. If the user selects “Fields and Layout side by side” 574 in control 470, field pane 452 is positioned along side layout pane 454 in task pane 450 to form a single integrated pane, as shown in FIG. 13. If the user selects “Fields only” 575 in control 470, field pane 452 is shown in isolation, as shown in FIG. 14. If the user selects “Layout only 2 by 2” 576 in control 470, layout pane 454 is shown in isolation with zones 455, 456, 457, 458 arranged in a 2×2 square, as shown in FIG. 15. If the user selects “Layout only 1 by 4” 577 in control 470, layout pane 454 is shown in isolation with zones 455, 456, 457, 458 arranged in a 1×4 square, as shown in FIG. 16.


In the example shown in FIG. 5, the fields in field pane 452 are listed in alphabetical order. For lists including OLAP type data such as that shown in FIG. 4, the measures are shown first, and the dimensions are shown in alphabetical order thereafter. In the examples shown, the dimension folders are shown in expanded form, with all other fields shown in collapsed form. Other configurations can also be used.


II. Automated Placement of a Field in Layout Pane


Referring again to FIG. 4, if a user selects a field by checking the checkbox associated with the field, program 200 is programmed to automatically place the selected field in one of the zones of layout pane 454, as described below.


Generally, fields of a numeric type are added to value zone 457, and fields of a non-numeric type are added to row zone 455 of layout pane 454. For example, fields of a numeric type (e.g., monetary sales figures) are typically aggregated and are therefore placed in value zone 457, while fields of a non-numeric type (e.g., product names) are typically used as row labels and are therefore automatically placed in row zone 455.


Referring now to FIG. 17, an example method 600 for automatically adding a selected field to one of the zones of layout pane 454 is shown. At operation 601, the user selects a field in field pane 452 using, for example, the checkbox associated with the field. Next, at operation 602, a determination is made regarding whether the field is of a numeric type. If the field is of numeric type, control is passed to operation 603, and the field is added to the value zone 457 for aggregation. If the field is determined to not be of numeric type at operation 602, control is passed to operation 604, and the field is added to the row zone 455.


In some embodiments, a field of numeric type can be further analyzed prior to adding the field to the value zone 457 to determine if a different placement in layout pane 454 is more appropriate. For example, a field including a plurality of zip code values is of numeric type, but it is typically desirable to place such a field in row zone 455, rather than in value zone 457. For this reason, fields of numeric type are further analyzed in some embodiments using data semantics to identify desired placement in layout pane 454.


In one embodiment, a lookup table, such as example Table 1 below, is used to identify fields of numeric type that are added to row zone 455 rather than value zone 457.













TABLE 1







FieldTypeString
MinValue
MaxValue




















“zip”





“year”



“quarter”
1
4



“qtr”
1
4



“month”
1
12



“week”
1
52



“day”
1
31



“id”



“number”



“social security number”



“ssn”



“phone number”



“date”











In Table 1, the column “FieldTypeString” includes text strings that are compared to the caption for the selected field, as described further below. In the example shown, the caption for the selected field is compared against each string in the FieldTypeString column of Table 1 to identify any case-insensitive matches.


If a match is made between a text string in the FieldTypeString column and the caption for the selected field, numeric items in the field are further analyzed using the values in the “MinValue” and “MaxValue” columns of Table 1. The value in the MinValue column specifies the minimum value of any of the items of the given FieldTypeString type. The value in the MaxValue column specifies the maximum value of any of the items of the given FieldTypeString type. If no MinValue is defined in Table 1 for a particular FieldTypeString type, a determination is made regarding whether the numeric items are integers below the MaxValue. If no MaxValue is defined for a particular FieldTypeString type, a determination is made regarding whether the numeric items are integers above the MinValue. If neither a MinValue nor a MaxValue is defined for a particular FieldTypeString type, a determination is made regarding whether the numeric items are integers.


For example, if a selected field includes the caption “Month,” Table 1 is parsed and a match is identified with FieldTypeString value “month.” Next, the numeric values associated with the field are parsed to determine if the numeric values fall within the minimum and maximum values “1” and “12” (representing January through December). In one embodiment, all numeric items for the field are tested. In other embodiments, such as when there are a significantly large number of numeric items, only a sample of the numeric items is tested against the minimum and maximum values in Table 1. If all of the values fall within the minimum and maximum values, then the field is added to the row zone 455, rather than the value zone 457, as described further below.


The text strings and minimum and maximum values shown in Table 1 are examples only, and different strings and values can be used. For example, the text strings and minimum/maximum values can be modified depending on the geographic location at which the data is generated (e.g., phone number values can differ depending on geographic location). In other embodiments, different types of semantic checking can be used. For example, the number of digits of the numeric items can be analyzed in addition to or in place of checking the actual values for the numeric items. For example, if a caption for a field matches the text string “zip” (i.e., zip codes), the number of digits for the numeric items in the field can be examined to see if the digits fall between a minimum of five (e.g., “90210” includes five digits) and a maximum of ten (e.g., “90210-1052” includes ten digits).


Referring now to FIG. 18, an example method 610 is shown for automatic placement of a selected field in layout pane 454. Method 610 is similar to method 600 described above, except that fields of numeric type are further analyzed. At operation 611, the user selects a field in field pane 452 using, for example, the checkbox associated with the field. Next, at operation 612, a determination is made regarding whether the field is of numeric type. If the field is of non-numeric type, control is passed to operation 613, and the field is added to row zone 455.


If the determination at operation 612 is that the field is of a numeric type, control is passed to operation 615. At operation 615, the caption for the field is parsed, and, at operation 616, the caption is compared to a lookup table of text strings such as that shown in Table 1 above. If a match between the caption and a text string is not made in operation 616, control is passed to operation 619, and the field is added to value zone 457. If a match in operation 616 between the caption and a text string in Table 1 is made, control is passed to operation 617.


At operation 617, numeric items of the field are parsed, and, at operation 618, the values of the numeric items are compared to the minimum and maximum values in Table 1 associated with the text string. If the numeric items fall outside the minimum and maximum values as described above, control is passed to operation 619, and the field is added to value zone 457. If the numeric items fall within the minimum and maximum values at operation 618, control is passed to operation 613, and the field is added to row zone 455.


In this manner, specific fields of numeric type can automatically be identified and placed in the row zone 455, rather than the default value zone 457. If a field is automatically placed by program 200 in a particular zone of layout pane 454 and the user wants the field to be placed in a different zone, the user can select and drag the field to the desired zone.


In some embodiments, fields associated with date information are identified and placed in column zone 456, rather than row zone 455 or value zone 457. For example, method 630 shown in FIG. 19 is similar to method 610 described above, including operations 61-619. However, at operation 618, if the numeric items fall within the minimum and maximum values, control is passed to operation 631. At operation 631, a determination is made as to whether the field is a date field. In the example shown, this determination is made by the text string to which the caption is matched. For example, if the caption for the field includes the text “Date” and is matched with the text string “date” in Table 1, then the field is identified as a date field. If the field is a date field, control is passed to operation 632, and the field is added to column zone 456. If the field is not a date field, control is passed to operation 613, and the field is added to row zone 455.


In alternative embodiments, Meta data associated with a particular field can be used to identify attributes about the field. For example, Meta data can be used to identify if a field is a numeric and/or a date field.


In some embodiments, the following rules are used when automatically adding a field identifying OLAP data to layout pane 454 and data summary table 320:


A. OLAP Hierarchies/OLAP Named Sets

    • 1. the hierarchy is added to the row zone
    • 2. the hierarchy is nested on the inside of all other fields in the row zone
    • 3. for hierarchies with multiple levels, the highest level field is displayed in the data summary table and the user can drill to see lower level fields


B. OLAP Measures/OLAP KPI Expressions

    • 1. if at least one measure is already added, the measure is added to the same zone as the already added measures
    • 2. adding the second measure introduces a Data field (see, for example, “Σ Values” field in FIG. 10) in the layout pane, and the Data field is placed in the column zone by default—the Data field is displayed in the layout zone when there are two or more fields in the value zone
    • 3. when added, the Data field is nested on the inside of all other fields in the column zone
    • 4. the Data field resides in either the row or column zones


In some embodiments, the following additional rules are used when automatically adding a field identifying non-OLAP data, or relational field, to layout pane 454 and data summary table 320:


A. for non-numeric fields, the field is added to the row zone—the field is nested on the inside of all other fields in the row zone


B. for numeric fields, the field is added to the value zone

    • 1. if at least one field is already in the value zone, this field will be added to the same zone as the already added field
    • 2. adding the first field to the value zone introduces the Data field in the layout pane, and the Data field is placed in the column zone by default
    • 3. when added, the Data field is nested on the inside of all other fields in the column zone
    • 4. the Data field resides in either the row or column zones


      III. Filtering Task Pane


Referring again to FIG. 11, one or more filters can be applied to items for a particular field to limit the information that is included in the data summary table 320. For example, the user can use drop down area 562 for a particular field listed in field pane 452 of task pane 450 to access a filtering task pane 700.


Referring now to FIG. 20, example filtering task pane 700 is shown. Interface 700 generally includes a field selector drop down control 705, a manual filter area 707, and a filtering control area 709.


Selector drop down control 705 can be used to select different fields for filtering. For OLAP data, the fields in selector drop down control 705 can be displayed in a hierarchical arrangement, and drop down control 705 can be used to select different levels of OLAP data for filtering. In the example shown, the field selected is the “Country” field.


Manual filter area 707 lists all of the items associated with the field shown in selector drop down control 705. Checkboxes are associated with each item listed in manual filter area 707 to allow the user to manually select which items are included in the filter. Referring to FIG. 21, for OLAP data, sub-items can be accessed by clicking on the drill indicator plus/minus (+/−) sign to expand and collapse the items associated with each field listed in manual filter area 707. For example, the “Drink” and “Food” items are shown in expanded form. Checkbox 713 is selected for the “Food” item, which results in the selection of each sub-item of “Food” as well. For the “Drink” item, only sub-item “Alcoholic Beverages” is selected, and checkbox 712 associated with the “Drink” item is provided with a mix indicator to show that only a portion of sub-items of the “Drink” item are selected. A “select all” checkbox 711 can be selected to select/deselect every item at all levels shown in filter area 707.


Referring again to FIG. 20, when the user uses selector drop down control 705 to select a different field, manual filter area 707 is updated accordingly to list the items associated with the field shown in selector drop down control 705. If the newly selected field is from another level of the same hierarchy as the originally selected field in selector drop down control 705, manual filter area 707 remains unchanged because all levels of items are shown in manual filter area 707 for OLAP data.


Filtering control area 709 lists the filter controls that are available for application to the selected field shown in selector drop down control 705. Controls 710 allow the user to change the order in which filtered items are listed. For example, the user can select one of controls 710 to have the filtered items listed in alphabetic order from A→Z or from Z→A. Control 715 is used to provide additional sorting options, such as, for example, sorting by a particular field.


The user can select control 720 to remove all filtering for the field in drop down selector 705. Controls 725 and 730 allow the user to select particular filters to apply to the field in drop down selector 705. For example, if the user selects control 725, the user is presented with a fly-out menu 740, shown in FIG. 22. Menu 740 lists a plurality of filters that can be applied to the selected field. The filters listed in menu 740 are those filters that are typically applied to label fields. These filters include, without limitation, “Begins With,” “Does Not Begin With,” “Ends With,” “Does Not End With,” “Contains,” and “Does Not Contain.” The user can select a filter from menu 740 to apply that filter to the items in the field. Likewise, the user can select control 730 to access fly-out menu 745, shown in FIG. 23. Menu 745 includes filters that can be applied to value fields. These filters include, without limitation, “Equals,” “Does Not Equal,” “Greater Than,” “Greater Than Or Equal To,” “Less Than,” “Less Than Or Equal To,” “Between,” and “Not Between.”


Referring now to FIG. 24, when the user selects a filter from one of the fly-outs 740, 745, the user is presented with a dialog box such as dialog box 760 to build the desired filter. In dialog box 760, a field selection box 772 is pre-populated with the with the selected field in selector drop down control 705, and a filter selection box 774 is pre-populated with the filter selected from fly-out 740, 745. The user can select a different field by selecting the drop down menu in field selection box 772 to, for example, access other fields currently included in value zone 457. The user can select a different filter by selecting the drop down menu in filter selection box 774, which provides a listing of all filters available for the data type. A criteria box 776 allows the user to place the value for filtering therein. For example, if the user selects the “Store Sales” item in manual filter area 707 and then selects the “Greater Than” filter from fly-out 745, dialog box 770 is presented to the user. The user can enter the value “50000” in criteria box 776 to set the filter to filter all Store Sales that are greater than $50,000.


Referring now to FIG. 25, controls 725 and 730 can be modified depending upon the type of field shown in selector drop down control 705. For example, task pane 700 includes a field of the date type and therefore includes control 725 that allows for filtering by date, and control 730 that allows for filtering by value. The user can select control 725 to access fly-out menu 760 shown in FIG. 26. Fly-out menu 760 includes a plurality of filters that can be applied to a field of data type.


In some embodiments, the user is presented with only those controls that are applicable to a selected field. For example, if the user selects a field of non-date and non-numeric type, control 725 is active to provide fly-out menu 740 with filters applicable to such a field. If the user selects a date field, control 725 is active to provide fly-out menu 760 with filters applicable to date fields. If the user selects a field of numeric, non-date type, control 730 is active to provide fly-out menu 745 with filters applicable to numeric data fields.


In some embodiments, filters can be associated with a given field before the field is added to the data summary table 320. The filter is actually applied when the particular field is added to the data summary table 320. In this manner, the amount of data that is accessed and summarized on data summary table 320 can be reduced, thereby increasing efficiency. If a filter is applied to a field that is already included in data summary table 320, data summary table 320 is updated in view of the filter to show only the filtered items.


Additional details regarding the application of the selected filters to the data is found in U.S. patent application Ser. No. 11/157,634, filed on Jun. 21, 2005 and entitled “Dynamically Filtering Aggregate Reports Based on Values Resulting from One or More Previously Applied Filters,” the entirety of which is hereby incorporated by reference.


A checkbox indicator 752 (see FIG. 25) in filtering pane 700 is placed adjacent to any filters that have been applied. Referring now to FIG. 27, once a filter is applied to a given field, a filter icon 810 is shown adjacent to the field in field pane 452 of task pane 450 to indicate that a filter is applied to the field. In some embodiments, a similar filter icon is also associated with each filtered field in layout pane 454 and in data summary table 320.


In addition, when the pointing device hovers over the particular field with filter icon 810, a tool-tip 830 is provided, as shown in FIG. 28. Tool-tip 830 lists the filtered fields in one of three sections, manual filters, label filters, and value filters. Tool-tip 830 also lists the filtered fields in the order of evaluation with the type of filter applied. For filters with longer labels, a portion of the label can be truncated as required to fit within the tool-tip. For each filter, tool-tip 830 shows that a manual filter is first applied to the “Year” field for years 2000, 2001, 2002, 2003, and 2004. Tool-tip 830 indicates that a text filter is then applied to the “Product Name” field, requiring the text “ab.” Additional filtering is also shown in tool-tip 830. In this manner, the user can identify which filters are applied for the data summary table 320, and can also identify the order in which the filters are applied by examining tool-tip 830.


In the example shown, the user can use drop down area 562 (see FIG. 11) for a particular field listed in task pane 450 to access filtering task pane 700. If the user accesses interface 700 from data summary table 320, the default field shown in selector drop down control 705 is the field that is currently selected in data summary table 320. The user can select another field using selector drop down control 705. In other embodiments, filtering task pane 700 can also be accessed from within data summary table 320 by selecting drop down areas 862 in data summary table 320. See FIG. 9. In other embodiments, the user can access filtering task pane 700 by selecting one or more fields in data summary table 320 and right-clicking on the selected fields to access one or more filtering options. These options can include, for example, including or excluding the selected fields in a manual filter, or filtering the selected fields using the label, date, or value filters describe above.


If filtering task pane 700 is accessed from data summary table 320, the fields listed in drop down control 705 can be selected based on where the user accesses interface 700. For example, if the user selects drop down area 862 from a field in a row of data summary table 320, all fields currently on rows are shown. If the user instead selects drop down area 862 from a field in a column of data summary table 320, all fields currently on columns are shown.


In the example shown, filtering information is stored with the particular field to which it is applied. For example, if filtering is applied to a field that is not part of data summary table 320, the filtering information is associated with the field and applied when the field is added to data summary table 320. Likewise, if a field with a filter is removed from data summary table 320, the filter information is retained with the field so that if the field is later added back to data summary table 320, the filter is reapplied. As noted above, filtering for a field can be removed by selecting the field and then selecting control 720 (see FIG. 20).


The various embodiments described above are provided by way of illustration only and should not be construed as limiting. Those skilled in the art will readily recognize various modifications and changes that may be made without following the example embodiments and applications illustrated and described herein, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.

Claims
  • 1. A method for improving efficiency of a computer device when creating a filtered data summary table, comprising: creating, by the computing device, a graphical user interface of an application for summarizing data, the graphical user interface comprising: a data summary table, wherein the data summary table is initially blank; anda task pane separate from the data summary table, the task pane including a row zone, a column zone and a value zone;receiving a selection of a first non-numeric field from a list of fields;receiving a selection of a first filter option available to the first non-numeric field;generating a first filtered value based on the first filter option;receiving a selection of the first non-numeric field for inclusion in the column zone;in response to receiving the selection of the first non-numeric field for inclusion in the column zone: displaying the first filtered value as a column label in the data summary table; andgenerating a first set of filtered numeric values from a numeric field based on the first filtered value prior to displaying data from the numeric data in the data summary table;receiving a selection of the numeric field for inclusion in the value zone; andin response to receiving the selection of the numeric field for inclusion in the value zone, displaying a summary of the first set of filtered numeric values below the column label in the data summary table.
  • 2. The method of claim 1, further comprising: receiving a selection of a second field from the list of fields;receiving a selection of a second filter option available to the second field;generating a second filtered value based on the second filter option;receiving a selection of the second field for inclusion in the row zone;in response to the inclusion of the second field in the row zone, displaying the second filtered value as a row label in the data summary table;generating a second set of filtered numeric values from the numeric field based on both the first and second filtered values; anddisplaying a summary of the second set of filtered numeric values at an intersection of the column label and the row label in the data summary table.
  • 3. The method of claim 2, wherein the second field is a non-numeric field.
  • 4. The method of claim 3, wherein the steps of displaying the first filtered value as a column label in the data summary table and displaying the second filtered value as a row label in the data summary table occur prior to receiving the selection of the numeric field for inclusion in the value zone and displaying the summary of the second set of filtered numeric values in the data summary table.
  • 5. The method of claim 3 wherein: the task pane further includes a filter zone; andthe selection of each of the first filter option and the second filter option occurs within the filter zone.
  • 6. The method of claim 3, wherein the task pane further includes a fields pane for selecting one or more fields for inclusion within at least one of the row zone, the column zone, and the value zone.
  • 7. The method of claim 1, further comprising: receiving a selection to remove the first non-numeric field from the column zone;in response to the removal of the first non-numeric field from the column zone, removing the column label from the data summary table while maintaining the generated first filtered value based on the first filter option;receiving a subsequent selection to include the first non-numeric field within the column zone; andin response to the subsequent inclusion of the first non-numeric field within the column zone, redisplaying the first filtered value as a column label in the data summary table.
  • 8. The method of claim 1, further comprising: receiving an indication that the first non-numeric field is dragged from the column zone and dropped in the row zone; andin response to the indication that the first non-numeric field is dropped within the row zone, removing the display of the column label in the data summary table, adding a display of the first filtered value as a row label in the data summary table, and displaying the summary of the first set of filtered numeric values adjacent the row label in the data summary table.
  • 9. A computer readable storage device storing computer readable instructions for improving efficiency of a computing device when providing a filtered data summary table, which when executed by a processor unit is operative to perform steps comprising: creating a graphical user interface of an application for summarizing data, the graphical user interface comprising: a data summary table, wherein the data summary table is initially blank; anda task pane separate from the data summary table, the task pane including a row zone, a column zone and a value zone;receiving a selection of a first non-numeric field from a list of fields;receiving a selection of a first filter option available to the first non-numeric field;generating a first filtered value based on the first filter option;receiving an indication that the first non-numeric field is associated with the row zone;in response to the association of the first non-numeric field with the row zone: displaying the first filtered value as a row label in the data summary table; andgenerating, prior to displaying numeric data from a numeric field in the data summary table, a first set of filtered numeric values from the numeric field based on the first filtered value;receiving a selection of the numeric field for inclusion in the value zone; andin response to receiving the selection of the numeric field for inclusion in the value zone, displaying a summary of the first set of filtered numeric values adjacent to the row label in the data summary table.
  • 10. The computer readable storage device of claim 9, wherein the steps further comprise: receiving a selection of a second field from the list of fields;receiving a selection of a second filter option available to the second field;generating a second filtered value based on the second filter option;receiving an indication that the second field is associated with the column zone; andin response to the association of the second field with the column zone, displaying the second filtered value as a column label in the data summary table;generating a second set of filtered numeric values from the numeric field based on both the first and second filtered values; anddisplaying a summary of the second set of filtered numeric values at an intersection of the row label and the column label in the data summary table.
  • 11. The computer readable storage device of claim 10, wherein the second field is a non-numeric field.
  • 12. The computer readable storage device of claim 11, wherein the steps of displaying the first filtered value as a row label in the data summary table and displaying the second filtered value as a column label in the data summary table occur prior to receiving the selection of the numeric field for inclusion in the value zone and displaying the summary of the second set of filtered numeric values in the data summary table.
  • 13. The computer readable storage device of claim 11 wherein: the task pane further includes a filter zone; andthe selection of each of the first filter option and the second filter option occurs within the filter zone.
  • 14. The computer readable storage device of claim 9, wherein the steps further comprise: receiving a selection to remove the first non-numeric field from the row zone;in response to the removal of the first non-numeric field from the row zone, removing the row label from the data summary table while maintaining the generated first filtered value based on the first filter option;receiving a subsequent selection to include the first non-numeric field within the row zone; andin response to the subsequent inclusion of the first non-numeric field within the row zone, redisplaying the first filtered value as a row label in the data summary table.
  • 15. The computer readable storage device of claim 9, wherein the steps further comprise: receiving an indication that the first non-numeric field is dragged from the row zone and dropped in the column zone; andin response to the indication that the first non-numeric field is dropped within the column zone, removing the display of the row label in the data summary table, adding a display of the first filtered value as a column label in the data summary table, and displaying the summary of the first set of filtered numeric values below the column label in the data summary table.
  • 16. A computer system with improved efficiency when providing a filtered data summary table, comprising: a processor unit; anda computer-readable storage device storing instructions that, when executed by the processor unit, cause the processor unit to perform operations to:create a graphical user interface of an application for summarizing data, the graphical user interface comprising: a data summary table, wherein the data summary table is initially blank; anda task pane separate from the data summary table, the task pane including a row zone, a column zone and a value zone;receive a selection of a first non-numeric field from a list of fields;receive a selection of a first filter option available to the first non-numeric field;generate a first set of filtered values based on the first filter option;receive an indication that the first non-numeric field is placed within the row zone;in response to receiving the indication that the first non-numeric field is placed within the row zone, display the first set of filtered values as first row labels in the data summary table;receive a selection of a second non-numeric field from the list of fields;receive a selection of a second filter option available to the second non-numeric field;generate a second set of filtered values based on the second filter option;receive an indication that the second non-numeric field is placed within the column zone;in response to the indication that the second non-numeric field is placed within the column zone, display the second set of filtered values as first column labels in the data summary table;after generating and displaying the first and second sets of filtered values: generate a first set of filtered numeric values from a numeric field based on the first and second sets of filtered values;receive a selection of the numeric field for inclusion in the value zone; andin response to receiving the selection of the numeric field for inclusion in the value zone, display a summary of the first set of filtered numeric values at an intersection of the first row labels and the first column labels in the data summary table.
  • 17. The computer system of claim 16, wherein: the task pane further includes a filter zone; andthe selection of each of the first filter option and the second filter option occurs within the filter zone.
  • 18. The computer system of claim 16, wherein the instructions further cause the processor unit to perform operations comprising: receive a selection of a third non-numeric field from the list of fields;receive a selection of a third filter option available to the third non-numeric field;generate a third set of filtered values based on the third filter option;receive an indication that the third non-numeric field is placed within the row zone; andin response to the indication that the third non-numeric field is placed within the row zone, display the third set of filtered values as second row labels in the data summary table.
  • 19. The computer system of claim 18, wherein the instructions further cause the processor unit to perform operations comprising: receive an indication that the third non-numeric field is dragged from the row zone and dropped in the column zone; andin response to the indication that the third non-numeric field is dropped within the column zone, remove the display of the second row labels in the data summary table and add a display of the third set of filtered values as second column labels in the data summary table.
  • 20. The computer system of claim 16, wherein the summary of the first set of filtered numeric values is generated from the first and second sets of filtered values, wherein the first and second sets of filtered values comprise a pre-filtered subset of the data to be summarized.
RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 13/311,736, filed Dec. 6, 2011, entitled “Filtering User Interface for a Data Summary Table,” and assigned U.S. Pat. No. 9,223,772, which is a continuation of U.S. patent application Ser. No. 11/223,631, filed Sep. 9, 2005, entitled “Filtering User Interface for a Data Summary Table,” and now U.S. Pat. No. 8,095,866, which application is also related to U.S. patent application Ser. No. 11/222,660, filed Sep. 9, 2005, entitled “Automated Placement of Fields in a Data Summary Table,” and now U.S. Pat. No. 7,480,675 and U.S. patent application Ser. No. 11/223,527, filed Sep. 9, 2005, entitled “User Interface for Creating a Spreadsheet Data Summary Table,” and now U.S. Pat. No. 8,601,383, the entireties of which are hereby incorporated by reference.

US Referenced Citations (106)
Number Name Date Kind
5093907 Hwong et al. Mar 1992 A
5247611 Norden-Paul Mar 1993 A
5255363 Seyler Oct 1993 A
5381517 Thorndike Jan 1995 A
5455903 Jolissaint et al. Oct 1995 A
5485618 Smith Jan 1996 A
5566291 Boulton et al. Oct 1996 A
5566330 Sheffield Oct 1996 A
5598519 Narayanan Jan 1997 A
5604854 Glassey Feb 1997 A
5632009 Rao et al. May 1997 A
5787411 Groff et al. Jul 1998 A
5883635 Rao et al. Mar 1999 A
5966716 Comer et al. Oct 1999 A
6026397 Sheppard Feb 2000 A
6078924 Ainsbury et al. Jun 2000 A
6085202 Rao et al. Jul 2000 A
6185582 Zellweger Feb 2001 B1
6205675 Ide Mar 2001 B1
6246410 Bergeron et al. Jun 2001 B1
6279016 De Vorchik et al. Aug 2001 B1
6349315 Sonoyama et al. Feb 2002 B1
6411313 Conlon et al. Jun 2002 B1
6453270 Durbin Sep 2002 B1
6496832 Chi et al. Dec 2002 B2
6507836 Nose et al. Jan 2003 B1
6535883 Lee et al. Mar 2003 B1
6549894 Simpson et al. Apr 2003 B1
6604095 Cesare et al. Aug 2003 B1
6626959 Moise et al. Sep 2003 B1
6659626 Markey Dec 2003 B1
6757867 Bauchot Jun 2004 B2
6829615 Schirmer et al. Dec 2004 B2
6839719 Wallace Jan 2005 B2
6854103 Teene Feb 2005 B2
6867788 Takeda Mar 2005 B1
6906717 Couckuyt et al. Jun 2005 B2
6988241 Guttman et al. Jan 2006 B1
7073133 Hughes Jul 2006 B2
7130812 Iyer et al. Oct 2006 B1
7143339 Weinberg Nov 2006 B2
7188169 Buus et al. Mar 2007 B2
7363306 Hao et al. Apr 2008 B1
7370047 Gorman May 2008 B2
7480675 Folting et al. Jan 2009 B2
7627552 Moore et al. Dec 2009 B2
7627812 Chamberlain et al. Dec 2009 B2
7657552 Welker et al. Feb 2010 B2
7770100 Chamberlain et al. Aug 2010 B2
7831539 Folting et al. Nov 2010 B2
8095866 Folting et al. Jan 2012 B2
8286072 Chamberlain et al. Oct 2012 B2
8601383 Folting et al. Dec 2013 B2
8914717 Chamberlain et al. Dec 2014 B2
9223772 Folting et al. Dec 2015 B2
20020010713 Egilsson Jan 2002 A1
20020013786 Machalek Jan 2002 A1
20020013789 Okuno et al. Jan 2002 A1
20020038217 Young Mar 2002 A1
20020049687 Helsper et al. Apr 2002 A1
20020054141 Yen et al. May 2002 A1
20020059233 Bauchot May 2002 A1
20020078086 Alden Jun 2002 A1
20020116417 Weinberg et al. Aug 2002 A1
20020120604 Labarge et al. Aug 2002 A1
20020120664 Horn Aug 2002 A1
20020175948 Nielsen Nov 2002 A1
20030030672 Hughes et al. Feb 2003 A1
20030225876 Oliver Dec 2003 A1
20040002827 Iguchi Jan 2004 A1
20040060001 Coffen et al. Mar 2004 A1
20040117731 Blyashov Jun 2004 A1
20040181507 Megiddo et al. Sep 2004 A1
20040205450 Hao et al. Oct 2004 A1
20040268237 Jones Dec 2004 A1
20050039033 Meyers et al. Feb 2005 A1
20050071737 Adendorff et al. Mar 2005 A1
20050089223 Krumm Apr 2005 A1
20050125377 Kotler et al. Jun 2005 A1
20050154769 Eckart Jul 2005 A1
20050192825 Cardno et al. Sep 2005 A1
20050210001 Lee Sep 2005 A1
20050216831 Guzik et al. Sep 2005 A1
20060002608 Haddon et al. Jan 2006 A1
20060013455 Watson et al. Jan 2006 A1
20060074866 Chamberlain Apr 2006 A1
20060075328 Becker et al. Apr 2006 A1
20060095276 Axelrod et al. May 2006 A1
20060136808 Chirilov Jun 2006 A1
20060167704 Nicholls Jul 2006 A1
20060224568 Debrito Oct 2006 A1
20060287998 Folting et al. Dec 2006 A1
20070061369 Folting et al. Mar 2007 A1
20070061746 Folting et al. Mar 2007 A1
20070074130 Folting et al. Mar 2007 A1
20070101252 Chamberlain et al. May 2007 A1
20070174228 Folting et al. Jul 2007 A1
20070204212 Chamberlain et al. Aug 2007 A1
20100042913 Chamberlain et al. Feb 2010 A1
20100251090 Chamberlain et al. Sep 2010 A1
20120079363 Folting et al. Mar 2012 A1
20120324328 Chamberlain et al. Dec 2012 A1
20140059412 Folting et al. Feb 2014 A1
20150100871 Chamberlain et al. Apr 2015 A1
20160335226 Chamberlain et al. Nov 2016 A1
20170075874 Folting et al. Mar 2017 A1
Foreign Referenced Citations (23)
Number Date Country
2 617 870 May 2015 CA
10-040050 Feb 1998 JP
11282941 Oct 1999 JP
2001067489 Mar 2001 JP
2001-067486 Jun 2001 JP
2005-038404 Feb 2005 JP
2005-228345 Aug 2005 JP
3734491 Jan 2006 JP
10-2004-0027270 Apr 2004 KR
10-2004-0048786 Jun 2004 KR
10-2004-0106278 Dec 2004 KR
10-2005-0077048 Aug 2005 KR
10-2005-0081532 Aug 2005 KR
2004106570 Aug 2005 RU
2 417 421 Apr 2011 RU
2 433 449 Nov 2011 RU
2 442 212 Feb 2012 RU
WO 0073937 Dec 2000 WO
WO 02063876 Aug 2002 WO
WO 2007032909 Mar 2007 WO
WO 2007032910 Mar 2007 WO
WO 2007032913 Mar 2007 WO
WO 2007100518 Sep 2007 WO
Non-Patent Literature Citations (153)
Entry
Tatsuaki; “Microsoft's Data Access Techniques”; DB Magazi; DB Magazine, vol. 15, No. 3, Copyright Jul. 1, 2005, 24 pgs. (No English Lang translation).
Scott et al., “PivotTable and PivotChart Reports, & Macros in Micro& Macros in Microsoft Excel”; Biostatistician III, Department of Biostatistics, Van; Biostatistician III, Department of Biostatistics, Vanderbilt University; https://www.mc.vanderbilt.edu/gcrc/workshop_files/2008-02-22.pdf; 20 pgs.
Singleton; OpenOffice.org User Guide for Version 1.1.x; http://www.openoffice.org/documentation/manuals/OOo1.x.x/user_guide.pdf; OpenOffice.org User Guide, 1.5; First Edition May 7, 2004; 441 pgs.
“Quattro Pro 9”; In Quattro Pro 9; Copyright © Corel Corporation and Corel Corporation Limited; http://www.ci.kinston.nc.us/pdfs/qp9en.pdf; 794 pgs.
Canadian Notice of Allowance Received in Patent Application No. 2636674, dated Nov. 28, 2013, dated Feb. 13, 2007, 1 Page.
EP Notice of Allowance Issued in Patent Application No. 06790086.0, dated Jul. 23, 2015, 7 Pages.
Japanese Notice of Rejection Issued in Japanese Patent Application No. 2008-530097, dated Oct. 12, 2012, 4 Pages.
Japanese Notice of Rejection Received in Patent Application No. 2012-044087, dated Aug. 27, 2013, dated Aug. 20, 2008, 2 Pages. (w/o English Translation).
Norwegian Office Action dated Aug. 12, 2015 in Appln. No. 20080639, 2 pgs.
Chinese Notice of Allowance in Application 200680033172.2, dated Jan. 13, 2012, 4 pgs.
Canadian Notice of Allowance in Application 2,617,866, dated Aug. 11, 2015, 1 page.
Japanese Notice of Allowance in Application 2012-044087, dated Jan. 4, 2016, pp.
Canadian Notice of Allowance in Application 2,836,444, dated Sep. 18, 2015, 1 page.
U.S. Official Action dated May 15, 2015 cited in U.S. Appl. No. 13/311,736, 10 pgs.
Notice of Allowance dated Aug. 18, 2015 cited in U.S. Appl. No. 13/311,736, 12 pgs.
U.S. Appl. No. 14/068,294, Office Action dated Mar. 11, 2016, 37 pgs.
U.S. Appl. No. 13/595,791, Notice of Allowance dated Apr. 5, 2016, 7 pgs.
U.S. Appl. No. 13/595,791, Notice of Allowance dated May 24, 2016, 4 pgs.
European Office Action in Application 07750931.3, dated Jun. 10, 2016, 7 pgs.
U.S. Appl. No. 11/223,631, filed Sep. 9, 2005, entitled “Filtering User Interface for a Data Summary Table”.
U.S. Appl. No. 13/311,736, filed Dec. 6, 2011, entitled “Filtering User Interface for a Data Summary Table”.
U.S. Appl. No. 11/222,660, filed Sep. 9, 2005, entitled “Automated Placement of Fields in a Data Summary Table”.
U.S. Appl. No. 11/223,527, filed Sep. 9, 2005, entitled “User Interface for Creating a Spreadsheet Data Summary Table”.
U.S. Appl. No. 14/068,294, filed Oct. 31, 2013, entitled “User Interface for Creating a Spreadsheet Data Summary Table”.
U.S. Appl. No. 11/260,520, filed Oct. 27, 2005, entitled “Variable Formatting of Cells”.
U.S. Appl. No. 12/547,760, filed Aug. 26, 2009, entitled “Variable Formatting of Cells”.
U.S. Appl. No. 13/595,791, filed Aug. 27, 2012, entitled “Variable Formatting of Values”.
U.S. Appl. No. 11/364,377, filed Feb. 27, 2006, entitled “Dynamic Thresholds for Conditional Formats”.
U.S. Appl. No. 12/794,876, filed Jun. 7, 2010, entitled “Dynamic Thresholds for Conditional Formats”.
U.S. Appl. No. 14/570,501, filed Dec. 15, 2014, entitled “Dynamic Thresholds for Conditional Formats”.
U.S. Appl. No. 11/333,895, filed Jan. 1, 2006, entitled “Graphical Representation of Key Performance Indicators”.
Balter, “Allison Balter's Mastering Microsoft® Office Access 2003”; Sams, Dec. 8, 2003; pp. 68-72.
Microsoft Office Assistance: Pivot Table reports 101; http://office.Microsoft.com/en-us/assistance/HA010346321033.aspx?mode=print, © 2005 Microsoft Corporation, 11 pages (printed Aug. 10, 2005).
Carlton Collins, Microsoft Business Solutions, Microsoft Excel Pivot Tables, “A Business Software Tip,” http/www.microsoft.com/businesssolutions/excel_pivot_tables_Collins.mspx?pf=true, 13 pages, updated Jun. 3, 2005 (printed Aug. 10, 2005).
Data Palette, Wikipedia, Oct. 2007, 1 pg.
Fink, Keith; “Overview of PivotTables and PivotCharts in Microsoft Access 2002” dated Aug. 16, 2001, 44 pages.
Chi, et al., “A Spreadsheet Approach to Information Visualization”, http://www2.parc.com/istl/projects/uir/pubs/items/UIR-1997-03-Chi-UIST97-Spreadsheet.pdf.
Chi et al., “A Spreadsheet Approach to Information Visualization”; In Proceedings of IEEE Symposium on Information Visualization; Oct. 21, 1997; http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.24.6964&rep=repl&type=pdf; 11 pgs.
Chi, “Exploring Visual Representations”, http://www-users.cs.umn.edu/˜echi/papers/infovis97/spread/node18.html, Jul. 22, 1997.
Treinish, “A Function-Based Data Model for Visualization”, http://researchweb.watson.ibm.com/people/l/lloydt/dm/function/dm_fn.htm.
Varshney, A., et al.; “FINESSE: A Financial Information Spreadsheet” Proceedings of the 1996 IEEE Symposium on Information Visualization Symposium, pp. 70-71.
“Spreadsheet Visual Analyzer ver. 1.0”; Download3000, ©2003-2004, http://www.download3000.com/download_12120.html; retrieved Feb. 1, 2006; 2 pgs.
Davenport, G.; “Numbers—A Medium That Counts” IEEE Computer Graphics & Applications 11(4):39-44, Jul. 1991.
Hallberg, B., et al.; Special Edition Using Microsoft Excel 97; Bestseller Edition; Oct. 16, 1997; Que Publishing; pp. 4, 10.
Person, R.; Special Edition Using Microsoft Excel 97; Dec. 17, 1996; Que Publishing; renumbered pp. 1-37.
Stinson et al., “Microsoft Office Excel 2003 Inside Out, Analysing Data with Pivot Table Reports”; Microsoft Office Excel 2003 Inside Out, Microsoft Press, Jan. 1, 2003; pp. 797-807.
Desmaris; “Using the Microsoft Pivot Table for Reliability Applications”; IEEE Annual Reliability Symposium; Reliability-Investing in the Future; Apr. 18, 1996; pp. 1-13.
Nakano; “Excel Function Cooking”; Nikkei Personal Computing, No. 460, pp. 201-204; Nikkei Business Publications, Inc.; Japan; Jun. 21, 2004.
Kimura; “Even if the Content is the Same; it Can Be Shown in Various Ways; Important Points for Utilizing Excel ‘Display Format’”; Nikkei PC 21, vol. 11, No. 3, pp. 72-73, Nikkei Business Publications Inc.; Japan, Feb. 1, 2006.
Dictionary.com, LLC; “Spreadsheet”; Jul. 16, 2012, p. 1, Copyright 2012; Available World Wide Web “http://dictionary.reference.com/browse/spreadsheet?s=t”, 3 pgs.
Protest Email “Microsoft patents same spreadsheet idea TWICE”; Oct. 10, 2012; Patnews@ns1.patenting-art.com; 5 pgs.
Wikipedia; “Choropoleth map”; accessed Oct. 11, 2012 at http://en.wikipedia.org/wiki/Choropleth_map; 4 pgs.
Slashdot.org; “Microsoft Patents 1826 Choropleth Map Technique”; Oct. 9, 2012; accessed Oct. 11, 2012 at http://yro.slashdot.org/story/12/10/09/2055240/microsoft-patents-1826-choropleth-map-technique; 27 pgs.
Anonymous; “Conditional Formatting”; Internet Citation, Aug. 3, 2004, Retrieved from: http://web.archive.org/web/20040803153634/http://www.cpearson.com/excel/cformatting.htm; retrieved May 28, 2008; 4 pgs.
Stein J.D.; “Spreadsheet Smarts”; Internet Citation, 2000, Retrieved from Internet: http://www/aicpa.org/pubs/jofa/jan2000/stein.htm; retrieved May 28, 2008; 4 pgs.
Abramovich, S. et al., “Spreadsheet Conditional Formatting: An Untapped Resource for Mathematics Education”; Internet Citation, Oct. 5, 2005; Retrieved from Internet: http://epublications.bond.edu.au/ejsie/voll/iss2/3/; 24 pgs.
Stolte et al., “Polaris: A System for Query, Analysis, and Visualization of Multidimensional Relational Databases”; In Proceedings of IEEE Transactions on Visualization and Computer Graphics, vol. 8, No. 1; Jan. 2002; http://graphics.stanford.edu/papers/polaris_extended/polaris.pdf; 14 pgs.
PCT Search Report dated Jan. 9, 2007, Appln No. PCT/US2006/033807.
PCT Search Report dated Jan. 11, 2007, Appln No. PCT/US2006/033808.
PCT Search Report and Written Opinion dated Feb. 16, 2007, Appln No. PCT/US2006/033876.
International Search Report dated Jul. 27, 2007, issued in PCT Appl. No. PCT/US2007/004131.
EP Search Report dated Nov. 17, 2008, Appln No. 06790086.0.
EP Search Report dated Jul. 20, 2009, Appln No. 06813959.1.
Chinese Office Action dated Aug. 14, 2009 in Appln No. 200680032790.5.
Chinese Office Action dated Aug. 21, 2009 in Appln No. 200780006781.3.
Chinese Office Action dated Oct. 23, 2009 in Appln No. 200680032784.X.
Japanese Notice of Rejection dated Nov. 10, 2009 in Appln No. 2008-530101.
Chinese Second Office Action dated May 6, 2010 in Appln No. 200680032784.X.
Chinese Office Action dated May 14, 2010 in Appln No. 20068003172.2, 11 pgs.
Chinese Second Office Action dated Jul. 30, 2010 in Appln No. 200680032790.5.
Japanese Notice of Rejection dated Nov. 18, 2011 in Appln No. 2008-530098.
Japanese Notice of Rejection dated Nov. 29, 2011 in Appln No. 2008-556365.
Extended EP Search Report dated Dec. 27, 2011, Appln No. 06802599.8.
Mexican Office Action with summary dated Apr. 25, 2012 in Appln No. MX/a/2008/003319.
Canadian Office Action dated May 10, 2012 in Appln No. 2617870, 5 pgs.
Japanese Notice of Rejection dated Aug. 10, 2012 in Appln No. 2008-556365.
Japanese Notice of Rejection dated Oct. 12, 2012 in Appln No. 2008-530097.
European Examination Report dated Oct. 23, 2012 in EP 56695RK900kap.
Japanese Notice of Rejection dated Mar. 5, 2013 cited in Appln No. 2012-036529.
Korean Notice of Rejection dated Mar. 29, 2013 cited in Appln No. 10-2008-7020125.
Korean Notice of Rejection dated Apr. 30, 2013 cited in Appln No. 10-2008-7005544.
Canadian OA dated Aug. 2, 2013 cited in Appln No. 2,636,674.
Notice of Allowance Received for Malaysia Patent Application No. PI 20080501, dated Aug. 30, 2013, dated Aug. 29, 2006, 2 pgs.
Malaysia Notice of Allowance Received in Patent Application No. PI 20082804, dated Sep. 13, 2013, dated Feb. 13, 2007, 2 Pages.
Notice of Allowance Received for Korea Republic of (KR) Patent Application No. 10-2008-7005544, dated Oct. 31, 2013, dated Aug. 29, 2006, 3 pgs.
Japanese Notice of Rejection dated Nov. 7, 2013 in Appln No. 2012-044087, 6 pgs.
Canadian OA dated Dec. 23, 2013 cited in Appln No. 2,617,866, 2 pgs.
Malaysian Substantive Examination Report dated Jan. 15, 2014 in Appln No. PI 20080498, 3 pgs.
EP Search Report dated Feb. 10, 2014 in Appln No. PCT/US2007/004131, 7 pgs.
Japanese Office Action Received in Patent Application No. 2012-044087, dated Mar. 18, 2014, dated Aug. 20, 2008, 5 Pages.
Canadian Notice of Allowance dated Apr. 3, 2014 in Appln No. 2,618,224, 2 pgs.
Canadian Notice of Allowance dated May 8, 2014 in Appln No. 2,617,866, 2 pgs.
EP Communication dated Jul. 22, 2014 in Appln No. 06 790 086.0, 5 pgs.
Canadian Office Action dated Aug. 7, 2014 in Appln No. 2,617,870, 2 pgs.
Mexican Notice of Allowance dated Aug. 12, 2014 in Appln No. MX/a/2008/009869, 4 pgs.
Canadian Office Action dated Dec. 18, 2014 in Appln No. 2,617,866, 4 pgs.
Norwegian Office Action and Search Report dated Feb. 10, 2015 in Appln No. 20080639, 6 pgs.
EP Communication dated Mar. 9, 2015 in Appln No. 14003694.8, 6 pgs.
Canadian Examiner's Report dated Mar. 24, 2015 in Appln No. 2,836,444, 5 pgs.
India First Examination Report dated Apr. 13, 2015 in 4383/CHENP/2008, 2 pgs.
Japanese Office Action Issued in Japanese Patent Application No. 2012-044087, dated Jul. 14, 2015, 4 pgs., (w/o English Translation).
India Examination Report dated Aug. 6, 2015 in 1947/DELNP/2008, 2 pgs.
India First Examination Report dated Sep. 29, 2015 in 1944/DELNP/2008, 2 pgs.
India First Examination Report dated Sep. 30, 2015 in 1983/DELNP/2008, 1 pg.
U.S. Official Action dated Oct. 24, 2007 cited in U.S. Appl. No. 11/333,895, 10 pgs.
U.S. Official Action dated Apr. 1, 2008 cited in U.S. Appl. No. 11/222,660, 11 pgs.
U.S. Official Action dated May 7, 2008 cited in U.S. Appl. No. 11/333,895, 11 pgs.
U.S. Official Action dated Dec. 24, 2008 cited in U.S. Appl. No. 11/223,631, 23 pgs.
U.S. Official Action dated Jan. 13, 2009 cited in U.S. Appl. No. 11/333,895, 17 pgs.
U.S. Official Action dated Mar. 4, 2009 cited in U.S. Appl. No. 11/260,520, 13 pgs.
U.S. Official Action dated Mar. 30, 2009 cited in U.S. Appl. No. 11/223,527, 33 pgs.
U.S. Official Action dated Aug. 5, 2009 cited in U.S. Appl. No. 11/223,631, 21 pgs.
U.S. Official Action dated Aug. 24, 2009 cited in U.S. Appl. No. 11/333,895, 18 pgs.
U.S. Official Action dated Aug. 25, 2009 cited in U.S. Appl. No. 11/364,377, 25 pgs.
U.S. Official Action dated Oct. 26, 2009 cited in U.S. Appl. No. 11/223,527, 38 pgs.
U.S. Official Action dated Dec. 14, 2009 cited in U.S. Appl. No. 11/223,631, 21 pgs.
U.S. Official Action dated Dec. 29, 2009 cited in U.S. Appl. No. 11/364,377, 19 pgs.
U.S. Official Action dated Dec. 31, 2009 cited in U.S. Appl. No. 11/333,895, 15 pgs.
U.S. Official Action dated Jun. 3, 2010 cited in U.S. Appl. No. 11/223,631, 21 pgs.
U.S. Official Action dated Jun. 22, 2010 cited in U.S. Appl. No. 11/223,527, 36 pgs.
U.S. Official Action dated Jul. 29, 2010 cited in U.S. Appl. No. 11/223,631, 18 pgs.
U.S. Official Action dated Aug. 12, 2010 cited in U.S. Appl. No. 11/333,895, 21 pgs.
U.S. Official Action dated Dec. 8, 2010 cited in U.S. Appl. No. 11/223,527, 39 pgs.
U.S. Official Action dated Dec. 27, 2010 cited in U.S. Appl. No. 11/223,631, 22 pgs.
U.S. Official Action dated Apr. 11, 2011 cited in U.S. Appl. No. 11/223,631, 21 pgs.
U.S. Official Action dated Apr. 13, 2011 cited in U.S. Appl. No. 11/223,527, 40 pgs.
U.S. Official Action dated Nov. 8, 2011 cited in U.S. Appl. No. 11/223,527, 41 pgs.
U.S. Official Action dated Mar. 19, 2012 cited in U.S. Appl. No. 12/794,876, 18 pgs.
U.S. Official Action dated Jul. 31, 2012 cited in U.S. Appl. No. 11/223,527, 48 pgs.
U.S. Official Action dated Aug. 15, 2012 cited in U.S. Appl. No. 12/794,876, 26 pgs.
U.S. Official Action dated May 9, 2013 cited in U.S. Appl. No. 12/794,876, 36 pgs.
U.S. Official Action dated Sep. 10, 2013 cited in U.S. Appl. No. 12/794,876, 24 pgs.
U.S. Official Action dated Apr. 7, 2014 cited in U.S. Appl. No. 12/794,876, 29 pgs.
U.S. Notice of Allowance dated Aug. 18, 2014 cited in U.S. Appl. No. 12/794,876, 23 pgs.
U.S. Official Action dated Dec. 3, 2014 cited in U.S. Appl. No. 13/595,791, 49 pgs.
U.S. Official Action dated May 1, 2015 cited in U.S. Appl. No. 13/595,791, 16 pgs.
Notice of Allowance dated Aug. 19, 2015 cited in U.S. Appl. No. 13/595,791, 11 pgs.
U.S. Appl. No. 14/068,294, Notice of Allowance dated Aug. 5, 2016, 7 pgs.
Indian Hearing Notice in Application 1947/DELNP/2008, dated Oct. 28, 2016, 2 pgs.
Office Action Issued in European Patent Application No. 06790086.0, dated Jul. 22, 2014, 5 pgs.
Office Action Issued in European Patent Application No. 06802599.8, dated Oct. 23, 2012, 4 pgs.
Search Report Issued in European Patent Application No. 07750931.3, dated Feb. 10, 2014, 7 pgs.
Notice of Allowance Action Issued in U.S. Appl. No. 11/260,520, dated Jul. 22, 2009, 9 pgs.
Notice of Allowance Action Issued in U.S. Appl. No. 11/260,520, dated Sep. 8, 2009, 15 pgs.
Non Final Office Action Issued in U.S. Appl. No. 12/547,760, dated Oct. 31, 2011, 16 pgs.
Notice of Allowance Action Issued in U.S. Appl. No. 12/547,760, dated Dec. 12, 2011, 8 pgs.
Notice of Allowance Action Issued in U.S. Appl. No. 12/547,760, dated Feb. 17, 2012, 8 pgs.
Notice of Allowance Action Issued in U.S. Appl. No. 12/547,760, dated May 10, 2012, 8 pgs.
Office Action Issued in Canadian Patent Application No. 2617870, dated Aug. 7, 2014, 2 pgs.
Indian Refusal Decision on Hearing in Application 1947/DELNP/2008, dated Dec. 7, 2016, 2 pgs. (English translation).
Indian Hearing Notice in Indian Application 4383/CHENP/2008, dated Mar. 3, 2017, 3 pgs.
U.S. Appl. No. 14/570,501, Office Action dated Apr. 13, 2017, 20 pgs.
Halberg et al., “Special Edition Using Microsoft Excel 97”, Best Seller Edition, Oct. 16, 1997, Que Publishing, pp. 139-141 and 913-915.
Related Publications (1)
Number Date Country
20160110337 A1 Apr 2016 US
Continuations (2)
Number Date Country
Parent 13311736 Dec 2011 US
Child 14981303 US
Parent 11223631 Sep 2005 US
Child 13311736 US