BUSINESS ANALYTICS
SESSION 2
ANALYTICS ON SPREADSHEET
ANALYTICS ON
SPREADSHEET
WHAT ARE WE
GOING TO
LEARN?
1. Basic Excel Skills
Understand basic operation of Excel (menus, shortcuts, formatting)
This Photo by Unknown Author is 2. Basic Excel Functions
licensed under CC BY-SA
Understand basic functions: MIN, MAX, AVERAGE, SUM, COUNT
3. Insert Function
Understand using insert function to explore functions to be used
This Photo by Unknown Author is
licensed under CC BY-SA
4. Logical Function
Understand using logical functions: AND, OR, IF (including SUMIF and COUNTIF)
5. Lookup Function
Understand using lookup function for database queries (additional: Pivot Table)
This Photo by Unknown Author is
licensed under CC BY-SA
Important Note: Use Microsoft Excel 2010 or newer version! Or use Excel Online using your UI Account!
Excel Office 365 (or Excel Online) version will be used throughout this course.
1. BASIC EXCEL SKILLS
EXCEL TABS AND MENUS
Tabs
Buttons
Groups
Consist of buttons classified by Groups.
Tabs
The display above show the Home tab.
Buttons are represented by icons.
Buttons
Some buttons may contain menus.
Groups Classification of icons/buttons Example of a button with menus
SOME FREQUENTLY USED SHORTCUTS
O Open a workbook H Go to Home tab
CTRL ALT
W Close a workbook H, H Choose a fill color
S Save a workbook N Go to Insert tab
C Copy H, A, C Center align cell contents
V Paste P Go to Page Layout tab
X Cut A Go to Data tab
W Go to View tab
Z Undo
H, B Add borders
Y Redo
H, D, C Delete column
B Bold
M Go to Formula tab
I Italic
U Underline
SHIFT F10 Open context menu
A Select all
9 Hide selected row(s) Find out more on:
https://support.microsoft.com/en-us/office/keyboard-shortcuts-in-
0 Hide selected column(s) excel-1798d9d5-842a-42b8-9c99-9b7213f0040f#bkmk_freqwin
FORMATTING
Number In Home Tab
Click this
for more
options
FORMATTING
Font In Home Tab
Click this
for more
options
FORMATTING
Others
More on Format Cells:
Alignment, Border, Fill,
Protection
2. BASIC EXCEL FUNCTIONS
COMMON MATHEMATICAL OPERATORS
() Parentheses
^ Exponentiation
* Multiplication
The order of operation applies in Excel
/ Division (mnemonic: PEMDAS)
+ Addition
- Subtraction
BASIC FUNCTIONS
Function Syntax Description
MIN =MIN(number1, [number2], …) Returns the minimum number in a range of values.
MAX =MAX(number1, [number2], …) Returns the maximum number in a range of values.
AVERAGE =AVERAGE(number1, [number2], …) Takes average of selected numbers.
SUM =SUM(number1, [number2], …) Adds values from a selection of columns, rows, ranges, or
individual inputs.
COUNT =COUNT(value1, [value2], …) Counts all cells in a range that contain numeric values only.
COUNTA =COUNTA(value1, [value2], …) Counts all cells in a range regardless of value types.
TRIM =TRIM(text) Eliminates all empty spaces in a cell that contains text.
Note:
The separator in syntax uses comma (,) if you use point (.) for expressing decimal.
The separator in syntax uses semicolon (;) if you use comma (,) for expressing decimal.
All Excel functions and description (alphabetical or by category) can be found on:
https://support.microsoft.com/en-us/office/excel-functions-alphabetical-b3944572-255d-4efb-bb96-c6d90033e188
https://support.microsoft.com/en-us/office/excel-functions-by-category-5f91f4e9-7b42-46d2-9bd1-63f26a86c0eb
3. INSERT FUNCTION
INSERT FUNCTION
Click this icon to open
Insert Function dialog
You can search for a function…
… or select from a category.
A list from search result will be displayed
here
INSERT FUNCTION
After a certain function has been selected (for example COUNT), a new dialog will
appeare to assist you in filling the inputs needed.
Inputs for the function (select from data)
Requirement for valid inputs
Result will be displayed
4. LOGICAL FUNCTION
LOGICAL FUNCTION
Function Syntax Description
AND =AND(logical1, [logical2], …) Returns TRUE if all of its arguments (logical statements) are
TRUE.
OR =OR(logical1, [logical2], …) Returns TRUE if any argument (at least one) is TRUE.
NOT =NOT(logical) Reverses the logic of its argument.
IF =IF(logical_test, [value_if_true], Specifies a logical test to perform.
[value_if_false])
IFS =IFS(logical_test1, [value_if_true1], Checks whether one or more conditions are met and
logical_test2, [value_if_true2], …) returns a value that corresponds to the first TRUE condition.
IFERROR =IFERROR(value, value_if_error) Returns a specified value if a formula evaluates to an error
(#N/A, #VALUE!, #REF!, #DIV/0!, #NUM!, #NAME?, or
#NULL!); otherwise, it returns the result of the formula.
All Excel functions and description (alphabetical or by category) can be found on:
https://support.microsoft.com/en-us/office/excel-functions-alphabetical-b3944572-255d-4efb-bb96-c6d90033e188
https://support.microsoft.com/en-us/office/excel-functions-by-category-5f91f4e9-7b42-46d2-9bd1-63f26a86c0eb
“IF” FUNCTION
=IF(logical_test, [value_if_true], [value_if_false]) Example 1: “Purchase Orders” Data
Logical test/condition If the logical test If the logical test Suppose that the quantity order of at least
is satisfied is not met 1,000 units is considered “Big” and below
Requirement(s) to be (TRUE), this (FALSE), this that is “Small”.
fulfilled. value will be value will be
It may include: displayed as displayed as
• = (equal to) output. output. Cell I4 =IF(F4>1000,"Big","Small")
• <> (not equal to)
• > (greater than) Exercise 1
• >= (greater than or In column J, create an IF function to
equal to) indicate the Arrival Status. An order is
• < (less than) assumed as “Late” if it arrives more than
• <= (less than or 14 days after its order date. Otherwise, it is
equal to) considered as “Not Late”.
NESTED “IF” VS “IFS” FUNCTION
Example 2: “Purchase Orders” Data Option 1: Nested If
=IF(F4<500,"Very Small",IF(F4<1000,"Small",IF(F4<10000,"Big","Very Big")))
Suppose we have more than two categories
of Order Size with the following Will be evaluated 1st Will be evaluated 2nd Will be evaluated 3rd Last condition
classification:
• Quantity < 500 → Very Small Option 2: Using IFS function
• 500 ≤ Quantity < 1,000 → Small
• 1,000 ≤ Quantity < 10,000 → Big =IFS(F4<500,"Very Small",F4<1000,"Small",F4<10000,"Big",TRUE,"Very Big")
• Quantity ≥ 10,000 → Very Big
1st logical test 2nd logical test 3rd logical test Last logical test
How do we make that classification? Exercise 2
In column M, create an IF/IFS function to classify Arrival Status:
More explanation on Nested If and avoiding its pitfalls: • <7 days of arrival → Fast
https://support.microsoft.com/en-us/office/if-function- • 7-14 days of arrival → Normal
%E2%80%93-nested-formulas-and-avoiding-pitfalls-
0b22ff44-f149-44ba-aeb5-4ef99da241c8
• >14 days of arrival → Late
MULTIPLE CONDITIONAL STATEMENTS
Example 3: “Purchase Orders” Data Qty Unit Cost Status
Suppose we have a classification system based on >1,000 >200 Highly Critical
more than one condition as follows: >1,000 ≤200 Critical
≤1,000 >200 Critical
How do we make that classification? ≤1,000 ≤200 Not Critical
Multiple Conditional Statements
=IFS(AND(F4>1000,E4>200),"Very Critical",AND(F4<=1000,E4<=200),"Not Critical",TRUE,"Critical")
Both conditional statements should Both conditional statements should Remaining condition
be met to get “Highly Critical”status. be met to get “Not Critical”status.
MULTIPLE CONDITIONAL STATEMENTS
Exercise 3
Using Order Size in Example 2 and Arrival Status in Exercise 2, create a
classification function using IF/IFS and other logical functions (AND, OR)
to produce the following Risk Status Classification:
Risk Status Classification Order Size
Based on Order Size and
Arrival Status Very Small Small Big Very Big
Fast Low Low Low Low
Arrival Status Normal Low Low Medium Medium
Late Medium Medium High High
OTHER FUNCTIONS WITH “IF”
Function Syntax Description
COUNTIF =COUNTIF(range, criteria) Counts the number of cells on a selected range that meet a
criterion.
COUNTIFS =COUNTIFS(criteria_range1, criteria1, Applies criteria to cells across multiple ranges and counts
[criteria_range2, criteria2]…) the number of times all criteria are met.
SUMIF =SUMIF(range, criteria, [sum_range]) Sums the values in a range that meet a specified criterion.
SUMIFS =SUMIFS(sum_range, Sums the values in a range that meet all the specified
criteria_range1, criteria1, criteria.
[criteria_range2], [criteria2], …)
MINIFS/ =MINIFS/MAXIMS(min_range, Returns the minimum/maximum value among cells
MAXIFS criteria_range1, criteria1, specified by a given set of conditions or criteria.
[criteria_range2, criteria2], ...)
AVERAGEIFS =AVERAGEIFS(average_range, Returns the average (arithmetic mean) of all cells that meet
criteria_range1, criteria1, multiple criteria.
[criteria_range2, criteria2], ...)
OTHER FUNCTIONS WITH “IF”
Example 4: “Purchase Orders” Data
Summarize the descriptive statistics (count, min, max, total, average) of order value for each supplier with “Big”Order
Size (based on Example 2 classification). Firstly, create a table to calculate Order Cost (Unit Cost * Quantity).
Supplier Order Size Number of Order Total Order Costs Minimum Order Costs Maximum Order Costs
PT Aberdeen Big ? ? ? ?
PT Brighton Big ? ? ? ?
PT Canterbury Big ? ? ? ?
PT Durham Big ? ? ? ?
PT Edinburgh Big ? ? ? ?
PT Flinshire Big ? ? ? ?
PT Glasgow Big ? ? ? ?
PT Hereford Big ? ? ? ?
OTHER FUNCTIONS WITH “IF”
Example 4: “Purchase Orders” Data
Summarize the descriptive statistics (count, min, max, total, average) of order value for each supplier with “Big”Order
Size (based on Example 2 classification). Firstly, create a table to calculate Order Cost (Unit Cost * Quantity).
Supplier Order Size Number of Order Total Order Costs Minimum Order Costs Maximum Order Costs
PT Aberdeen Big 5 38,722.50 1,260.00 9,750.00
=COUNTIFS($B$4:$B$97,R4,$L$4:$L$97,S4)
=SUMIFS($P$4:$P$97,$B$4:$B$97,R4,$L$4:$L$97,S4)
=MINIFS($P$4:$P$97,$B$4:$B$97,R4,$L$4:$L$97,S4)
=MAXIFS($P$4:$P$97,$B$4:$B$97,R4,$L$4:$L$97,S4)
5. LOOKUP FUNCTION
DATABASE QUERIES
Is there any purchase order to How many orders are there to
PT Aberdeen on January 26, PT Canterbury for Shielded
2020? If yes, how many? Cable/ft. - type 1?
What is the total order cost to
What type of item purchased
PT Durham with “Very
in Order No. 2020010053?
Critical”status?
DATABASE QUERIES Using Filter: Block Database and Select “Filter” from “Data” Tab
Is there any purchase order to
PT Aberdeen on January 26,
2020? If yes, how many?
DATABASE QUERIES Result Using Filter:
Is there any purchase order to
PT Aberdeen on January 26,
What if we would like to compare with purchase order on another date?
2020? If yes, how many? With another supplier? According to item description? Etc.
Using filter feature will be inefficient.
Solution: Use Lookup Function and Pivot Table
1 LOOKUP FUNCTION
2 MATCH + INDEX
3 PIVOT TABLE
1 DATABASE QUERIES: VLOOKUP
Function Syntax
VLOOKUP =VLOOKUP(lookup_value, table_array, col_index_num, [range_lookup])
Lookup function can be used when what we are searching for has a unique identifier such as ID number.
For each unique identfier (lookup value), the function only returns one result.
Example 5: “Purchase Orders” Data
What type of item purchased in Order
No. 2020010053?
lookup_value = Y4 (2020010053)
table_array = A4:H97 (database range) → first column of table_array should always be the identifier column
col_index num = 4 (Item Description is in the 4th column)
range_lookup = 0 or FALSE (for Exact Match); if range_lookup = 1 or TRUE, it will return Approximate Match)
1 DATABASE QUERIES: HLOOKUP AND XLOOKUP
Function Syntax
HLOOKUP =HLOOKUP(lookup_value, table_array, row_index_num, [range_lookup])
XLOOKUP =XLOOKUP(lookup_value, lookup_array, return_array, [if_not_found], [match_mode], [search_mode])
• HLOOKUP is the inverse version of VLOOKUP. It is used when the header of database is in column, instead of in
row.
• XLOOKUP is more flexible than VLOOKUP. The identifier does not have to be in the first column of the table array.
Exercise 4
Using XLOOKUP, find the item description for Order No. 2020010053.
2 DATABASE QUERIES: INDEX + MATCH
Function Syntax Description
INDEX =INDEX(array, row_num, [column_num]) Returns the value of an element in a table or an array,
selected by the row and column number indexes.
MATCH =MATCH(lookup_value, lookup_array, Searches for a specified item in a range of cells, and then
[match_type]) returns the relative position of that item in the range
XMATCH =XMATCH(lookup_value, lookup_array, Searches for a specified item in an array or range of cells,
[match_mode], [search_mode]) and then returns the item's relative position.
Example 6: “Monthly Sales” Data Cell L2 =INDEX(B4:F21,MATCH(I1,A4:A21,0),MATCH(I2,B3:F3,0))
Compare Sales Value in the period
ending July 31, 2019 for Jakpus and Returns row number Returns column
Jakbar branches. for input Period number for input
Branch
Returns data from
database for given
inputs
Inputs Results from INDEX + MATCH
3 PIVOT TABLE
Pivot table is a powerful tool to calculate, summarize, and analyze data to understand comparisons,
patterns, and trends in your data.
Step 1 Block database area to be analyzed.
Step 2 Select Pivot Table from Insert tab.
Step 3 Make comparisons and analysis.
3 PIVOT TABLE
Example 7: “Purchase Orders” Data
How many orders are there to PT We can perform Filter function to
Canterbury for Shielded Cable/ft. - select certain value/criteria from
data.
type 1?
All Suppliers in the database will be
presented by columns.
All Item Description in the database
will be presented by rows.
The content of the new table will
present the Sum of Quantity order.
Values can be changed into count,
average, min, max, etc.
3 PIVOT TABLE
Result
This is the answer, but
we can compare with
other items or other
suppliers.
3 PIVOT TABLE
Exercise 5
Create a pivot table showing the total order costs by suppliers and
critical status (based on Example 3).
What is the total order cost to
PT Durham with “Very
Critical”status?
Thank You