Excel 2007 Tips for Efficient Users
Excel 2007 Tips for Efficient Users
Introduction
My purpose with this Excel tutorial is to illustrate some Excel tips that will dramatically improve your efficiency. I make no attempt to be as encyclopedic as some of the 800-page Excel manuals available. I concentrate on common tasks, not every last thing that can be done in Excel. Also, I presume that you have some Excel knowledge. For example, I assume you know about rows and columns, values, labels, and formulas, relative and absolute addresses, and other basic Excel elements. If you know virtually nothing about Excel, you probably ought to work through an Excel for Dummies book and then work through this tutorial. The style of this tutorial should be easy to follow. Main topics appear in bold black type. Specific direction headings are in yellow, and these are followed by detailed directions in red. Additional comments about the directions appear in blue. Then there are Try it! exercises in green. These Try it! exercises are a key feature of this tutorial. I have embedded numerous sample Excel spreadsheets so that you can try out the directions right awaywithout switching into Excel. When you double-click on one of these spreadsheets, you launch Excel, and the spreadsheet comes alive. The menus and toolbars even change to those for Excel. By clicking outside one of these spreadsheets, youre back in Word. The easiest way to maneuver around this tutorial is to switch to outline view. To do so, select Words ViewOutline menu item, which gives you an extra Outlining menu. Select this menu and then click on the Show Level dropdown. This lets you choose the level of the outline. Youll get good results by choosing Level 2. This lets you see all first-level and second-level headings. Put your cursor on a heading of interest and then switch back to normal view by selecting Words ViewPrint Layout menu item. (Try it right now. Its easy!) Finally, I suggest that you save this fileRIGHT NOWas MyXLTutorial.docx (or some such name) and work with the copy. That way, if you mess anything up as you try the exercises, you can always go back and retrieve the original file (ExcelTutorial.docx). Have fun!
experiment with the various options. While youre at it, note the options along the left when you click on the Office button. For example, thats where you find Save As and Print, two obvious favorites. You cant change the new ribbons; they are built in and fixed. However, you can customize the user interface to some extent. First, Excel gives you a quick access toolbar (QAT) at the top left of the screen. You can put your favorite buttons on this toolbar so that theyre always visible and available. The QAT comes with a few favorite buttons, but you can add more. Just click on the dropdown arrow to the right of the QAT and check any of your favorites (or click on More Commands to get more buttons). Second, if you dont mind writing a bit of XML, you can create new ribbons that have your favorite Excel buttons or even new buttons attached to your own macros. (This is somewhat advanced, so it wont be covered in this document.) With the old menus gone, what about the keyboard shortcuts many of you depend on? As far as I can tell, they still work, or at least most of them still work. For example, you can still press Ctrl-s to save a file or Ctrl-p to print a file. However, in this document, where Ive embedded spreadsheets, the keyboard shortcuts for Excel wont work. This is evidently because the spreadsheets are embedded in a Word document. One other important change is file extensions. Unless you wrote your own add-ins in earlier versions of Excel, the only file extension you probably ever saw was .xls. You can still save files with this extension, but theyll lose any features new to Excel 2007. To save them and keep new features, you should save them as .xlsx files. Note that if you do so, people with Excel 2003 wont be able to open them unless they download and install a free file format converter from Microsoft. (Google for Microsoft Office Compatibility Pack to find this free download.) One other new file extension is .xlsm. If your Excel file has associated VBA macros, then you should save it as an .xlsm file.
Chris Albright
Page 2
5/18/2012
The action of an End-arrow combination depends on where you start. It takes you to the last nonblank cell if you start in a nonblank cell. (If there arent any nonblank cells in that direction, it takes you to the far edge of the sheet.) If you start in a blank cell, it takes you to the first nonblank cell.
Selecting a Range
Usually in Excel, you select a range and then do something to it (such as enter a formula in it, format it, delete its contents, and so on). Therefore, it is extremely important to be able to select a range efficiently. Its easy if the whole range appears on the screen, but its a bit trickier if you
Chris Albright
Page 3
5/18/2012
cant see the whole range. In the latter case the effect of dragging (the method most users try) can be frustratingthings scroll by too quickly. Try one of the methods below instead. To select a range that fits on a screen: Click on one corner of the range and drag to the opposite corner. Or: Click on one corner, hold down the Shift key, and click on the opposite corner. Try it! Select the range B2:D7.
To select a range doesnt fit on a screen: Click on one corner of the range, say, the upper left corner. Then, holding the Shift key down, use the End-arrow combinations (End and right arrow, then, if necessary, End and down arrow) to get to the opposite corner. Or: Split the screen so that one corner shows in one pane and the opposite corner shows in the other pane. Click on one corner, hold the Shift key down, and click on the opposite corner. Try it! Select the range B2:C100 or the range E2:N5. Try both of the methods suggested above.
Chris Albright
Page 4
5/18/2012
For example, to select the ranges B2:D5 and F2:H5, click on B2, hold down the Shift key and click on D5 (so now the first range is selected), hold down the Ctrl key and click on F2, and finally hold down the Shift key and click on H5. Try it! Select all three numerical ranges shown.
10 1 5 13 9 4 7 12 1 6 15 9 7 1 12 2
13
10
To copy and paste using toolbar buttons: Proceed as above, but use the copy and paste buttons (in the left section of the Home ribbon) instead of the Ctrl-c and Ctrl-v key combinations. Try it! Copy the formula in C2 down through cell C8 using the Copy and Paste buttons.
Chris Albright
Page 5
5/18/2012
Buttons or key combinations? This is a matter of personal taste, but either is quicker than menu choices! A frequent task is to enter a formula in one cell and copy it down a row or across a column. There are several very efficient ways to do this. To avoid copying and pasting altogether, use Ctrl-Enter: Starting with the top or left-hand cell, select the range where the results will go. (Use the selection methods described earlier, especially if this range is a long one.) Type in the formula, and press Ctrl-Enter instead of Enter. Try it! Fill up the range C2:C8 with Ctrl-Enter.
Pressing Ctrl-Enter enters what you typed in all of the selected cells (adjusted for relative addresses), so in general, it can be a real time saver. For example, it can be used to enter the number 10 in a whole range of cells. Just select the range, type 10, and press Ctrl-Enter. Try it! Fill up the range B2:D8 with the value 10 by using Ctrl-Enter.
Chris Albright
Page 6
5/18/2012
Enter the formula in the top or left-hand cell of the intended range. Place the cursor on the drag handle at the lower right of this cell (the cursor becomes a plus sign), and drag this handle down or across to copy. Try it! Copy the formula in C2 down through C8 with the drag handle.
To copy by double-clicking on the drag handle: Enter the formula in the top or left-hand cell of the intended range. Double-click on the drag handle. This method uses Excels built-in intelligence, but it works only in certain situations. Lets say you have numbers in the range A3:B100. You want to enter a formula in cell C3 and copy it down to cell C100. Because this is a common thing to do, Excel does it for you if you doubleclick on the drag handle. It senses the filled-up range in column B and guesses that you want another filled-up range right next to it in column C. If there were no adjacent filled-up range, double-clicking on the drag handle wouldnt work. Try it! Copy the formula in C2 down through C8 by double-clicking the drag handle.
Chris Albright
Page 7
5/18/2012
You might want to experiment with the other options in the Paste dropdown. For example, if you have a set of labels entered as a row and you want this same set of labels entered somewhere else as a column, try copying and pasting with the Transpose option.
Absolute/Relative References
Absolute and references are indicated in formulas by dollar signs or the lack of them, and they indicate what happens when you copy or move a formula to a range. You typically want some parts of the formula to stay fixed (absolute) and others to change relative to the cell position. This is a crucial concept for efficiency in spreadsheet operations, so you should take some time to understand it thoroughly. Here are two important things to remember: (1) The dollar signs are relevant only for the purpose of copying or moving; they have no inherent effect on the formula. For example, the formulas =5*B3 and =5*$B$3 in cell C3, say, produce exactly the same result. Their difference is relevant only if you want to copy cell C3 to some range. (2) There is never any need to type the dollar signs. This can be done with the F4 key.
Chris Albright
Page 8
5/18/2012
To make a cell reference absolute or mixed absolute/relative using the F4 key: Enter a cell reference such as B3 in a formula. Then press the F4 key. In fact, pressing the F4 key repeatedly cycles through the possibilities: B3 (neither row nor column fixed), then $B$3 (both column B and row 3 fixed), then B$3 (only row 3 fixed), then $B3 (only column B fixed), and back again to B3. Try it! Enter the appropriate formula in cell B7 and copy across to E7. (Scroll to the right to see the correct answer.)
Try it again! Enter one formula with appropriate absolute/relative addressing in cell C5 that can be copied to C5:F9. (Scroll to the right to see the correct answer.)
Table of revenues for various unit prices and units sold Units sold 50 Unit price $3.25 $3.50 $3.75 $4.00 $4.25
100
150
200
Showing Formulas in R1C1 Notation Speaking of relative and absolute addresses in formulas, its pretty amazing how intelligent spreadsheets are. When you copy a formula in cell C1 such as =A1+B1 down, it automatically changes appropriately: =A2+B2, then =A3+B3, etc. In a sense, these are all the same formula. Each says to add the two values to the left of the current cell. Excel allows you to see this equivalence even more clearly by viewing the formulas in a different format, called R1C1 notation. In this format, each of the formulas in column C is written as =RC[-2]+RC[-1]. R stands for row, and C stands for column. The fact that there is nothing next to R means we stay in the same row. The numbers in brackets next to C mean to go 2 columns to the left and 1 column to the left. (For columns, negative numbers mean to go to the left, positive to the right. For rows, negative numbers mean to go up, positive down.) If there is a number next to R or C that is not in brackets, it indicates an absolute reference. For example, =R2C[2] placed in cell D5 is equivalent to =F$2 since the row reference is absolute and the column reference is relative to column D.
Chris Albright
Page 9
5/18/2012
The usual way of expressing formulas, such as =C5+D5, is called A1 format. The new way discussed here is called R1C1 format. You can easily toggle between them. To toggle between A1 and R1C1 formats: Select the Office button, select Excel options, select Formulas, and check or uncheck the R1C1 reference style option. Try it! Toggle between A1 and R1C1 reference style in the following spreadsheet, and for either, examine the formulas inside the border and in the Total row. (Note: As far as I can tell, youll have to actually open Excel to try this one. When you double-click on the spreadsheet below, the Excel menu appears, but not the Office button. So you evidently cant change the Excel options from within Word. I suppose that makes sense.)
Multiplication table 1 2 3 4 Total 1 1 2 3 4 10 2 2 4 6 8 20 3 3 6 9 12 30 4 4 8 12 16 40
I have read one Excel book that advocates the use of R1C1 notation everywhere, reasoning that this notation makes more logical sense. Maybe the author has a point, but the A1 notation is so ingrained in most of us that the transition to R1C1 notation would probably start a revolt among millions of Excel users! Inserting and Deleting Rows or Columns
Often you want to insert or delete rows or columns. Note that deleting a row or column is not the same as clearing the contents of a row or columnmaking all of its cells blank. Deleting a row or column means wiping it out completely. To insert one or more blank rows: Click on a row number and drag down as many rows as you want to insert. Then click on the Insert dropdown and select Insert Sheet Rows. (Interestingly, the Insert dropdown is in the Cells group of the Home ribbon, not on the Insert ribbon.) The rows you insert are inserted above the first row you selected. For example, if you select rows 8 through 11 and then insert, four blank rows will be inserted between the old rows 7 and 8. Try it! Insert blank rows for the data for Feb, Apr, and May.
Chris Albright
Page 10
5/18/2012
Columns are inserted in the same way. Try it! Insert blank columns for sales reps Baker, Miller, and Smith (so that the sales reps are in alphabetical order from left to right).
Sales rep Commission rate Sales Commission Allison 5.4% $15,000 $810 Jones 6.5% $12,000 $780 Taylor 4.3% $17,000 $731
To delete one or more rows: Click on a row number and drag down as many rows as you want to delete. Then select the Delete dropdown and select Delete Sheet Rows. Columns are deleted in exactly the same way. Try it! The company no longer carries products K322 and R543, so get rid of their rows.
Filling a Series
Say you want to fill column A, starting in cell A2, with the values 1, 2, and so on up to 1000. There is an easy way. To fill a column range with a series: Enter the first value in the first cell (1 in cell A2). With the cursor in the starting cell (A2), select the Fill dropdown and then select the Series option to obtain a dialog box. (The Fill dropdown is in the Editing group of the Home ribbon.) Change the Rows setting to Columns, make sure the
Chris Albright
Page 11
5/18/2012
Type setting is Linear, make sure 1 is in the Step Value box, enter the final value (1000) in the Stop Value box, and click on OK. As you can guess from this dialog box, many other options are possible. Dont be afraid to experiment with them. Try it! The series of days in column A should go from 1 to 25, in column D it should go from 26 to 50.
Summation Button
The SUM function is used so often to sum across rows or columns that a button (the button) is available to automate the procedure. To illustrate its use, suppose you have a table of numbers in the range B3:E7. You want the row sums to appear in the range F3:F7, and you want the column sums to appear in the range B8:E8. Its easy. To produce row and column sums with the summation button: Select the range(s) where you want the sums (F3:F7 and B8:E8remember how to select multiple ranges?), and click on the summation button. Note that if you select multiple cells, you get the sums automatically. If you select a single cell (such as when you have a single column of numbers to sum), youll be shown the sum formula for your approval and youll have to press Enter to actually enter it. Why does Excel do it this wayyour guess is as good as mine! Try it! Use the summation button to fill in the row and column sums.
The summation button is in the Editing group of the Home ribbon. If you want a sum, click directly on the button. Alternately, you can click on the AutoSum dropdown for other options, including Average, Max, Min, and others.
Chris Albright
Page 12
5/18/2012
Transposing a Range
Often you set up a spreadsheet and then decide that you would rather have a portion of it transposed. That is, you would like to turn it on its side, so that rows become columns and vice versa. This is simple with one of Excels Paste options. To transpose a range: Select a range that you want to transpose and press Ctrl-c to copy it. Then select the upper left cell of the range where you want the transposed version to go, select the Paste dropdown, and select the Transpose option. Make sure there is enough room for the transposed version. For example, if the original range has 3 rows and 5 columns, the transposed version will have 5 rows and 3 columns. If you select cell D5, say, as the upper left cell for the transposed version, everything in the range D5:F9 will be overwritten by the transposed version. Try it! Transpose the range A3:D6 to a range with upper left cell F3.
Sales figures Jan 2300 4300 5500 Feb 3200 3500 6500 Mar 4500 4200 6000
Range Names
Range names are extremely useful for making your formulas more understandable. After all, which formula makes more sense: =B20-B21 or =Revenue-Cost? Efficient use of range names takes some experience, but here are a few useful tips. To create a range name: Select a range that you want to name. Then type the desired range name in the upper left name box on the screen. (This box is just above the column A heading. It usually shows the cell address, such as E13, where the cursor is.) You can also select the Formulas menu and use the Define Name option in the Defined Names group to name a range, but typing the range name in the name box is quicker and more intuitive. By the way, range names are not case sensitive, so that Revenue, revenue, and REVENUE can be used interchangeably. Try it! Name the rectangular range containing the numbers Data.
Chris Albright
Page 13
5/18/2012
71 15 14 40 28 41 28
31 74 49 43 72 56 81
9 46 25 20 30 90 43
69 84 38 75 92 89 81
5 27 83 83 75 73 61
When you type the range name in the name box, make sure you then press Enter to make the name stick. Its easy to type the name and then click on some other cell without pressing Enter. (Ive done it hundreds of time.) If you do so, youll find that the range name was not created. To delete a range name: Select the Name Manager in the Defined Names group of the Formulas ribbon. This shows a list of all range names in your workbook. Click on the one you want to delete, and then click on the Delete button. Suppose a range has name Costs and you want to rename it UnitCosts. If you highlight the range, the name box will show Costs. If you then overwrite this with UnitCosts in the name box, the range will have two names, Costs and UnitCosts. There is nothing inherently wrong with this, but if you want only a single name, UnitCosts, you will have to delete the Costs name, as described here. Try it! The numerical range is currently named Data. Delete this range name and then rename the range Database.
Suppose you have the labels Revenue, Cost, and Profit in cells A20, A21, and A22, and you would like the cells B20, B21, and B22 (which will contain the values of revenue, cost, and profit) to have these range names. Heres how to do it quickly. To create range names from adjacent labels: Select the range consisting of the labels and the cells to be named (A20:B22). Then click on the Create from Selection button in the Defined Names group of the Formulas ribbon. In the resulting dialog box, make sure the appropriate option (in this case, Left Column) is checked, and click on OK. Excel tries (usually successfully) to guess where the labels are that you want to use as range names. If it guesses incorrectly, you can always override its guess. Try it! Name the ranges A3:A8, B3:B8, and so on according to the labels in row 2.
Chris Albright
Page 14
5/18/2012
Sometimes you enter a formula using cell addresses, such as =B20-B21. Later, you name B20 as Revenue and B21 as Cost. The formula does not change to =Revenue-Cost automatically. However, it would be nice to make it change (and hence become more readable). In Excel 2003 and previous versions, you could highlight the formula and use the InsertNameApply menu item to change the formula so that it showed range names. However, this option appears to have been deleted in Excel 2007. You can use the Use in Formula option from the Defined Names group, but this is basically just a crutch to help you redefine your formula. Microsoft evidently had its reasons for deleting this functionality, but Im not what they were. Too bad! To see a list of all range names and check which ranges they apply to: Click on the down arrow at the right of the name box, and click on any of the range names you see. That range will then be selected automatically. Try it! There are five named ranges below. Locate them.
Sometimes it is straightforward to use range names in formulas. For example, if B20 is named Revenue and B21 is named Cost, then entering the formula =Revenue-Cost in, say, cell B22 is a natural thing to do. But consider this situation. The range B3:B14 contains revenues for each of 12 months, and its range name is Revenue. Similarly, C3:C14 contains costs, and its range name is Cost. For each month you want that months revenue minus cost in the appropriate cell in column D. You will get it correct if you select the range D3:D14, type the formula =RevenueCost, and press Ctrl-Enter. If you click on any cell in this range, youll see the formula =Revenue-Cost. This is pretty amazing. How does Excel know that the formula in D3, for example, is really =B3C3? Lets just say that its smart enough to figure this out. If it confuses you, however, you can always enter =B3-C3 and copy it down. Then youre safe, but youve lost the advantage of range names! Try it! Enter the formula for all of D3:D14 using range names. (If you like, calculate profits again in column E in the usual way, without range names.)
Chris Albright
Page 15
5/18/2012
Profit
To paste a list of all range names on a sheet: To document your spreadsheet, it is often useful to create a list of all of your range names and their corresponding cell addresses. This is easy with Paste Names option. To paste a list of all range names and corresponding addresses, select a cell with plenty of blank space below it, select the Use in Formula dropdown in the Defined Names group, and click on the Paste Names option. Try it! Paste a list of all range names, starting in cell D2.
Revenue Cost Profit $34,000 $22,000 $12,000 Range names used:
SUM Function
The SUM function is probably the most used Excel function of all. It sums all values in one or more ranges. To use the SUM function: Enter the formula =SUM(range), where range is any range. This sums the numerical values in the range. Actually, it is possible to include more than one range in a SUM formula, as long as they are separated by commas. (This can also be done with the COUNT, COUNTA, AVERAGE, MAX, and MIN functions discussed below.) For example, =SUM(B5,C10:D12,Revenues) is allowable (where Revenues is the name for some range). The result is the sum of the numerical values in all of these ranges combined. Note that if any cell in any of these ranges contains a label rather than a number, it is ignored in the sum. Chris Albright Page 16 5/18/2012
Try it! Use the SUM function in cell B10 to calculate the total of all costs.
Table of costs for units produced in one month (along side) for use in another month (along top) Feb $5,000 Mar $5,500 $6,100 Apr $4,400 $5,400 $4,300 May $3,900 $4,700 $6,900 $4,900
AVERAGE Function
The AVERAGE function averages all of the numeric cells in a range. To use the AVERAGE function: Enter the formula =AVERAGE(range) where range is any range. This produces the average of the numeric values in the range. Note that the AVERAGE function ignores labels and blank cells in the average. So, for example, if the range C3:C50 includes scores for students on a test, but cells C6 and C32 are blank because these students havent yet taken the test, then =AVERAGE(C3:C50) averages only the scores for
Chris Albright
Page 17
5/18/2012
the students who took the test. (It does not automatically average in zeros for the two who didnt take the test.) Try it! Use the AVERAGE function to calculate the averages in cells B1 and B2. (For B2, youll have to replicate the exam scores in column C and make some changes.)
SUMPRODUCT Function
There are many times when you need to sum products of values in two (or possibly more than two) similar-sized ranges. Fortunately, there is an Excel function that sums products quickly. To use the SUMPRODUCT function Enter the formula =SUMPRODUCT(range1,range2), where range1 and range2 are exactly the same size. For example, they might be two column ranges with 10 cells each, or they might be two ranges with 4 rows and 10 columns each. The formula sums the products of the corresponding values from the two ranges.
Chris Albright
Page 18
5/18/2012
There can actually be more than two ranges in the SUMPRODUCT formula, separated by commas, as long as all of them have exactly the same size. This is not as common as having only two ranges, but it is sometimes useful Try it! Sum the products of the two ranges in the following spreadsheet to find the total shipping cost. Enter the result in cell G1. (Scroll to the right for the answer.) By the way, if you are tempted to write the formula without the SUMPRODUCT function as the sum of 9 products, as many of my students continue to do, imagine how long your formula would be if there were 10 plants and 50 cities!
Unit shipping costs Plant1 Plant2 Plant3 Units shipped Plant1 Plant2 Plant3 City1 1.25 1.15 1.35 City1 155 250 0 City2 1.35 1.45 1.45 City2 180 130 210 City3 1.55 1.25 1.15 City3 0 185 140 Total cost
IF Function
IF functions are very useful, and they vary from simple to complex. Ill provide a few examples. To enter a basic IF function: Enter the formula =IF(condition,expression1,expression2), where condition is any condition that is either true or false, expression1 is the value of the formula if the condition is true, and expression2 is the value of the formula if the condition is false. A simple example is =IF(A1<5,10,NA). Note that if either of the expressions is a label (as opposed to a numeric value), it should be enclosed in double quotes. Try it! Enter appropriate IF formulas in columns C and D. (Scroll to the right to see the correct answer.)
For each product, if the end inventory is less than or equal to 50 units, enough units are ordered to bring stock back up to 200; otherwise, no units of that product are ordered Product End inventory Order placed (yes or no)? # of units ordered 1 100 2 40 3 20 4 70
Sometimes IF functions are nested. For example, there might be three possibilities, depending on whether the value in cell A1 is negative, zero, or positive. A nested IF formula can then be used as follows. To use nested IF functions: Enter the formula =IF(condition1,expression1,IF(condition2,expression2,expression3)). If condition1 is true, the relevant value is expression1. Otherwise, condition2 is checked. If it is true, the relevant value is expression2. Otherwise, the relevant value is expression3. Chris Albright Page 19 5/18/2012
An example is =IF(A1<0,10,IF(A1=0,20,30)). Suppose this formula is entered in cell B2. Then if A1 contains a negative number, B2 contains 10. Otherwise, if A1 contains 0, B2 contains 20. Otherwise (meaning that A1 must contain a positive value), B2 contains 30. Try it! Use a nested IF function to fill in the grades in column C. (Scroll to the right to see the correct answer.)
Each student gets an A (if score is 90 or above), S for satisfactory (if score if 60 or above but less than 90) or U for unsatisfactory if score is below 60 Student 1 2 3 4 5 6 Score 70 95 55 80 60 90 Grade
Sometimes more complex conditions (AND/OR conditions) are useful in IF functions. These are not difficult once you know the syntax. To use an AND condition in an IF function: Enter the formula =IF(AND(condition1,condition2),expression1,expression2). This results in expression1 if both condition1 and condition2 are true. Otherwise, it results in expression2. Note the syntax. The keyword AND is followed by the conditions, separated by a comma and enclosed within parentheses. Also, note that more than two conditions could be included in the AND, all separated by commas. Try it! Use an IF function with an AND condition to fill in the bordered range. (Scroll to the right to see the correct answer. Note the double quotes for labels.)
Investor sells stock only if its price has gone up three consecutive days (including the current day) Day Price change Sell (yes or no)? 1 Up 2 Down 3 Up 4 Up 5 Up 6 Down
To use an OR condition in an IF function: Enter the formula =IF(OR(condition1,condition2),expression1,expression2). This results in expression1 if either condition1 or condition2 is true (or if both are true). Otherwise, it results in expression2. Again, more than two conditions could be included in the OR. Try it! Use an IF function with an OR condition to fill in the bonuses in column F. (Scroll to the right to see the correct answer.)
Chris Albright
Page 20
5/18/2012
Any student who scores at least 95 on any of the exams gets a bonus which is 1% of their total score. Student 1 2 3 4 5 6 Exam 1 87 77 80 82 78 75 Exam 2 83 72 95 87 94 83 Exam 3 83 74 79 96 81 80 Exam 4 80 97 75 88 79 72 Bonus
Chris Albright
Page 21
5/18/2012
To use a VLOOKUP function: Create a lookup table with at least two columns, where the values in the first column are in ascending order, and (for best results) give the table range a range name. Then enter the formula =VLOOKUP(value,lookup table,column #), as described above. Try it! Enter a lookup table in columns E and F, and VLOOKUP functions in column C. Assume there is a quantity discount pricing scheme: for orders less than 300 units, the unit price is $3; for orders of at least 300 units but less than 400, the unit price is $2.50; for orders of 400 units or more, the unit price is $2. (Scroll to the right to see the correct answer.)
Order # Units sold Total cost 1 373 2 475 3 459 4 441 5 238 6 349 7 344 8 203
There are times where the first column of the lookup table are not sorted in ascending order. This is still allowable, but then you need to include the fourth argument with value FALSE in the VLOOKUP function. In this case, VLOOKUP will look for an exact match and will return an error if doesnt find an exact match. Try it! Use a VLOOKUP function in column C to find the gradepoints for each student. Note that the grades in column E of the lookup table are in the natural order, but they are not in Excels A-Z sort order. Therefore, FALSE must be entered as the fourth argument in the VLOOKUP function.
Student Grade Adams B Davis AEdwards C+ Johnson BMyers B+ Smith A Thomson C Gradepoints Grade A AB+ B BC+ C CGradepoints 4 3.7 3.3 3 2.7 2.3 2 1.7
Chris Albright
Page 22
5/18/2012
Select a blank cell where you want the function to go. Press the fx button and click on the category that seems most appropriate (Financial in this case). Scan through the list for a likely candidate and select it (try PMT). At this point you can get help, or you can press the OK button and enter the appropriate arguments for the function (interest rate, term, and principal, the latter expressed as a negative number). Try it! Use the function wizard to help you determine the function in cell B6. Use the range names in cells B3 through B5 for improved readability. (Scroll to the right to see the correct formula.)
Payments for Mr. Jones, who just bought a new car Amount financed Annual interest rate Term (number of months financed) Monthly payment $15,000 8.90% 36
Data Tables
Data tables, also called what-if tables, allow you to see very quickly how one or more outputs change as one or two key inputs change. There are two types of data tables: one-way tables and two-way tables. A one-way table has one input and any number of outputs. A two-way table has two inputs but only one output. Ill demonstrate both types. To illustrate, suppose Mr. Jones buys a new car for $20,000, makes a $5,000 down payment, and finances the remaining amount over the next 36 months at an 8.5% annual interest rate. There are at least two outputs that might be of interest: the monthly payment and the total interest paid through the duration of the loan. These are affected by at least two inputs: the amount of the down payment and the annual interest rate. Lets first look at a simple one-way data table, which illustrates how a single output, monthly payment, varies as the annual interest rate varies. This is shown in the following spreadsheet.
Price of car Down payment Amount financed Annual interest rate Number of payments Monthly payment Total interest paid $20,000 $5,000 $15,000 8.50% 36 $473.51 $2,046.47 Data table Interest rate Monthly payment $473.51 8.00% $470.05 8.25% $471.78 8.50% $473.51 8.75% $475.25 9.00% $477.00
To create the above table (which I already did): Enter a link for the output in cell E3. Because the monthly payment was calculated with the PMT function in cell B7, simply enter =B7 in cell E3. Then, starting in cell D4, enter any sequence of interest rates. Select the entire tablethe range D3:E8. Next, select the Data menu, and in the Data Tools group, select Data Table from the What-If Analysis dropdown. Finally, enter B4 as the column input cell. There is no row input cell, so leave it blank. Chris Albright Page 23 5/18/2012
It is important to understand what happens when you do this, so read this paragraph several times until it sinks in. Excel takes each interest rate in column D, substitutes it into the column input cell you designated (cell B4), recalculates the formula in cell E3 (the one I colored gray for emphasis) with this new interest rate, and records the answer in the data table. You use a column input cell because the possible inputs (interest rates) are listed in a column. It is also possible to capture multiple outputs in a one-way data table. An example appears below, where the single input is still the interest rate, but there are two outputs: monthly payment and total interest paid. This table is formed exactly as before except that the table range is now D3:F8.
Price of car Down payment Amount financed Annual interest rate Number of payments Monthly payment Total interest paid $20,000 $5,000 $15,000 8.50% 36 $473.51 $2,046.47 Data table Interest Monthly payment $473.51 8.00% $470.05 8.25% $471.78 8.50% $473.51 8.75% $475.25 9.00% $477.00 Total interest $2,046.47 $1,921.64 $1,983.98 $2,046.47 $2,109.09 $2,171.86
Try it! Create a one-way data table that shows the monthly payments and the total interest paid for each term (value in cell B5) from 12 to 48 in increments of 12. (Scroll to the right for the correct answer.)
Price of car Down payment Amount financed Annual interest rate Number of payments Monthly payment Total interest paid $20,000 $5,000 $15,000 8.50% 36 $473.51 $2,046.47
Two-way tables allow you to vary two inputs, one along a row and one along a column, and capture a single output in the body of the table. The following spreadsheet illustrates this, where the annual interest rate and the amount of the down payment both vary, and the single output is the monthly payment.
Price of car Down payment Amount financed Annual interest rate Number of payments Monthly payment Total interest paid $20,000 $5,000 $15,000 8.50% 36 $473.51 $2,046.47 Data table of monthly payment $473.51 $4,000 $5,000 8.00% $501.38 $470.05 8.25% $503.23 $471.78 8.50% $505.08 $473.51 8.75% $506.94 $475.25 9.00% $508.80 $477.00 $6,000 $438.71 $440.33 $441.95 $443.57 $445.20
Chris Albright
Page 24
5/18/2012
Enter the formula =B7 for the single output in the upper left corner, cell D2, of the data table. (Again, I colored this cell gray for emphasis.) Enter any sequence of down payments to the right of this and any sequence of interest rates below this. Next, select the Data menu, and in the Data Tools group, select Data Table from the What-If Analysis dropdown. Finally, enter B2 as the row input cell, and enter B4 as the column input cell. Note that B2 is the row input cell because various down payments are entered in a row (E2:G2). Similarly, B4 is the column input cell because interest rates are entered in a column. Excel substitutes each down payment into cell B2, each interest rate into cell B4, calculates the formula in cell D2, and records the answer (monthly payment) in the body of the table. Try it! Create a two-way data table that shows the total interest paid for each term from 12 to 48 in increments of 12, and each down payment from $3000 to $5000 in increments of $1000. Put down payments along the side, terms along the top. (Scroll to the right for the correct answer.)
Price of car Down payment Amount financed Annual interest rate Number of payments Monthly payment Total interest paid $20,000 $5,000 $15,000 8.50% 36 $473.51 $2,046.47
Fortunately, there is a much better way. Logically, we observe that every name has a comma and a space. The first name is what comes after the comma and space, and the last name is what Chris Albright Page 25 5/18/2012
comes before it. For the name Jones, Bob, there are 10 characters (including the comma and space, and the comma and space are characters 6 and 7. So the first name is the rightmost 3 characters and the last name is the leftmost 5 characters. In any parsing operation, this is the first and probably the most crucial step: find a pattern.
To use the LEN function: Enter the formula =LEN(text). This returns the number of characters in text. To use the RIGHT function: Enter the formula =RIGHT(text, n), where n is an integer. This returns the rightmost n characters in text. (If n is greater than LEN(text), it return the entire text.) To use the LEFT function: Enter the formula =LEFT(text, n), where n is an integer. This returns the leftmost n characters in text. (If n is greater than LEN(text), it return the entire text.) To use the MID function: Enter the formula =MID(text,s,n), where s is an integer and n is an optional integer. If n is missing, this returns all of text from character s on. (s stands for start.) Otherwise, it returns n characters of text, starting with character s. Here are some examples: The function =MID(Freddie,5) returns die. The function =MID(Freddie,5,2) returns di.
Chris Albright
Page 26
5/18/2012
Between these five functionsFIND, LEN, RIGHT, LEFT, and MIDyou can do some powerful text manipulation in Excel, and this can save hours of tedious typing. You will be the hero at your office! We now solve the above name-parsing problem in a series of steps, as indicated below. In cell B1, we use LEN to get the length of the text in cell A1. In cell C1, we use FIND to find the position of the comma. In cell D1, we add 1 to find the position of the space after the comma. We then find the first name with the RIGHT function, using the rightmost (10-7) characters. Similarly, we find the last name with the LEFT function, using the leftmost (6-1) characters. The beauty of this method is that we have to do it only once, in row 1. Then we can copy all of the formulas down for the rest of the names, even if there are 5000 of them! (Try it below. Copy the formulas down.)
Jones, Bob Davis, Stephen Thompson, Andy Wilson, John Fredericks, Kathy Williams, Karen Smith, Tom Jennings, Peter Benson, Ted Samson, Jason 10 6 7 Bob Jones
Try it! This is a bit more difficult than the name-parsing exercise above. Now each name is a first name, then a middle initial and a period, and then a last name. The goal is to have three columns with the first name, the middle initial (no period), and the last name. (Scroll to the right for a possible solution. This solution finds each piece of the name in a single formula. You might prefer to break it up into several formulas.)
Bob E. Jones Stephen C. Davis Andy T. Thompson John F. Wilson Kathy C. Fredericks Karen D. Williams Tom T. Smith Peter F. Jennings Ted R. Benson Jason E. Samson
Concatenating Text
The opposite of parsing text is concatenating text. To parse text, we start with a long piece of text and separate it into pieces. To concatenate, we start with two or more pieces of text and string them together. For example, we might parse Bob Jones into Bob and Jones. In the other direction, we might concatenate Bob and Jones into Bob Jones. The key to concatenating in Excel is the ampersand symbol, &. To concatenate the text in cells A1 and B1, for example, enter the formula =A1&B1 in cell C1. Literal text can also be included, such as =A1&, &B1. In this case, if A1 contains Jones and B1 contains Bob, then C1 will contain Jones, Bob. This concatenates the last name, a literal comma and space, and the first name.
Chris Albright
Page 27
5/18/2012
Try it! Concatenate the first names, middle initials, and last names in columns A, B, and C so that full names of the form Jones, Bob E. appear in column D.
Bob Stephen Andy John Kathy Karen Tom Peter Ted Jason E C T F C D T F R E Jones Davis Thompson Wilson Fredericks Williams Smith Jennings Benson Samson
Chris Albright
Page 28
5/18/2012
with 3 decimals to see the serial values. Then reformat them as date-times (in formats you can choose).
3/14/04 1:30 PM 12/31/1901 3:50 12:00 PM 29-Feb-96 9/24/46 14:45
Chris Albright
Page 29
5/18/2012
DATEDIF Function
Because dates are stored as numbers, it is possible to perform arithmetic on them. One particular arithmetic operation makes sense: subtraction. If you subtract one date from another, you find the number of days between them. You can do this by simple subtraction of cells, or you can get more control with the DATEDIF function. If you use simple subtraction, you automatically get
Chris Albright
Page 30
5/18/2012
the difference in days. For example, the formula =A1-A2, where A1 contains 11/25/2004 and A2 contains 11/20/2004, gives 5. The DATEDIF function provides more options. (Evidently, DATEDIF has been in Excel for years, but its documentation in online help has been sporadic. See the interesting article at http://www.cpearson.com/excel/datedif.htm.) To use the DATEDIF function: Enter the formula =DATEDIF(earlierdate,laterdate,interval), where interval can be y, m, d, or a few other options not covered here. If interval is y (quotes required), this returns the number of years between the two dates. Similarly, if interval is m or d, it returns the number of months or number of days between the two dates. Try it! Use simple subtraction of cells to find the number of days between the following two dates. Then use DATEDIF with the three options described above to get the number of days, months, and years between the two dates. (Note: Youll have to reformat the answer in cell B6 as a number. Excel wants to format it as a date for some odd reason. Scroll to the right for the answers.)
Dates of last two physical exams First exam Next exam Days (subtraction) Days (DATEDIF) Months (DATEDIF) Years (DATEDIF) 4/5/1999 7/15/2003
Chris Albright
Page 31
5/18/2012
Dates imported from a legacy system Nov 25, 1997 Nov 26, 1997 Nov 29, 1997 Dec 1, 1997 Dec 3, 1997
Statistical Functions
There are many statistical functions built into Excel. Ive already discussed the simplest statistical function, the AVERAGE function. (Statisticians often call this the mean, or the sample mean, but its simply the average of a set of numbers.) In this section Ill discuss a few other statistical functions.
The mode is the most likely value, the one that occurs most often. If no value occurs more than once or twice, then the mode isnt very useful. However, if a clothing retailer records the size of each dress sold, then the mode is quite useful. It is the best-selling dress size. Excels MODE function calculates the mode. To use the MODE function: Chris Albright Page 32 5/18/2012
Enter the formula =MODE(datarange), where datarange is any range that contains a set of values. Try it! Calculate the mode of the set of values in the above spreadsheet. How many times does this value occur? (Again, answers are to the right.)
The PERCENTILE function takes any percentage (expressed as a decimal number) and returns the value such that the given percentage of all values is below this value. For example, if we use the percentage 10% (0.10) and the PERCENTILE function returns 45, then we know that 10% of all values in the data set are below 45 and 90% are above it. To use the PERCENTILE function: Enter the formula =PERCENTILE(datarange,pct), where pct is any percentage expressed as a decimal, such as 0.10 for 10%. Try it! Find the requested percentiles in the above spreadsheet, and place your formulas in column G. For example, P10 indicates the 10th percentile. Do you see the relationship between the quartiles and certain percentiles? (Again, answers to the right.) Note that the QUARTILE and PERCENTILE functions are typically used on data sets with a large number of observations. If they are used on a very small data set, you might be surprised at the results. In fact, you might even disagree with them. For example, if the data set has the 5 Chris Albright Page 33 5/18/2012
values 10, 20, 30, 40, and 50, Excels PERCENTILE function indicates that the 10th percentile is 14. This is certainly not a very intuitive answer, and you might disagree with it, but we might ask why someone would want the 10th percentile of a 5-value data set in the first place!
The LARGE and SMALL functions are less well-known Excel functions, but they can be useful. Lets say we have a data set with 250 values and we want the 10 largest values. Then we can find these with the LARGE function, using arguments 1 through 10. Similarly, we can use the SMALL function to find the 10 smallest values. To use the LARGE function: Enter the formula =LARGE(datarange,k), where k is any integer from 1 to the number of data values. This returns the kth largest value. To use the SMALL function: Enter the formula =SMALL(datarange,k), where k is any integer from 1 to the number of data values. This returns the kth smallest value. Typically, we would enter a sequence of values of k in some column, enter the LARGE or SMALL formula for the first of them, and then copy down. Try it! For the data set in column A, which extends well below row 10, find the 10 largest values and 10 smallest values in columns D and E. Use the values of k in column C. (Scroll to the right for the answers.)
Chris Albright
Page 34
5/18/2012
679.02 1208.42 1635.72 729.63 1036.08 716.62 972.92 1175.68 1271.38 1048.93
1 2 3 4 5 6 7 8 9 10
Chris Albright
Page 35
5/18/2012
Financial Functions
Excel has a wide assortment of financial functions that are used by thousands of financial analysts every day. Ill illustrate the most common of these. If youre going to be a financial analyst, you should become familiar with the others!
PMT Function
The PMT function is usually used to find the monthly payment for a car loan or a home mortgage loan. The inputs are typically an annual interest rate, a term (number of months financed), and the amount borrowed (the principal). The PMT function finds the amount you have to pay each month of the term. Part of this payment is principal and part is interest. At the end of the term, you will have paid just enough to pay off the entire loan. To use the PMT function: Enter the formula =PMT(interestrate,term,principal). For technical reasons, if you want PMT to return a positive value, you should enter the principal as a negative number. The interest rate argument should be the monthly rate (assuming youre paying monthly), which is the annual rate divided by 12. Try it! Suppose you take out a $30,000 loan for a new car when the annual interest rate is 6.75% and the term of the loan is 36 months. Calculate your monthly payment in cell B4. Then use a data table (the perfect place for one!) to see how your monthly payment varies for terms of 24, 36, 48, or 60 months. (Scroll to the right to see the answers.)
Principal Annual interest Term Payment $30,000 6.75% 36 Data table for payment versus term
Chris Albright
Page 36
5/18/2012
Try it! Assume a company pays $100,000 at the beginning of year 1 to get into an investment. It then receives the cash inflows at the ends of years 1 through 5 shown below. What is the NPV of this investment (inflows minus outflows) with the given discount rate? Does the NPV increase or decrease as the discount rate increases? Why? (Scroll down to see the answer.)
Discount rate Initial payment 12% $100,000
2 $35,000
3 $50,000
4 $45,000
5 $35,000
If a company incurs cash inflows or outflows at irregular times, such as January 15, then May 30, then July 1, and so on, the NPV function cannot be used. You could go back to your finance book to see how to discount future payments directly, but there is an easier way, using the little-known XNPV function. This function is actually part of the Analysis ToolPak that ships with Excel. However, you might not have it loaded. To check, click on the Office button, then Excel Options, then Add-Ins, and then Go. If the Analysis ToolPak item isnt checked, check it. Then you can use the XNPV function. To use the XNPV function: Enter the formula =XNPV(discountrate,cashvalues,dates), where discountrate is the same as with NPV and cashvalues and dates are a stream of pairs of cash values and the dates when they are incurred. Typically, the first cash value will be an outflow and the rest will be inflows. In this case, the initial outflow (investment) should be included in the XNPV function, and the NPV will be discounted back to the date of this initial payment. This payment should be entered as a negative number. Try it! First make sure the Analysis ToolPak is loaded. Then find the net present value of the stream of cash inflows shown below, where the first is really a payment at the beginning of 2005. (Scroll down to see the answer.)
Discount rate 12%
Stream of cash flows Date 1-Jan-05 25-May-05 15-Sep-05 15-Jan-06 30-Jun-06 Cash ($85,000) $22,500 $31,000 $65,500 $55,000 NPV
IRR Function
Companies often have investment opportunities where they pay initially and then get returns in the future. When discussing NPV, I illustrated in the Try it! exercise that the NPV of such an investment decreases as the discount rate increases. In fact, for large enough discount rates, the Chris Albright Page 37 5/18/2012
NPV will typically become negative, meaning that the future returns are not enough to offset the initial cost. The discount rate at which NPV changes from positive to negative is called the internal rate of return, or IRR. Specifically, the IRR is the discount rate at which NPV equals 0. Companies are interested in IRR for the following reason. They typically have a hurdle rate that they use to discount potential investments. If the NPV of an investment is positive, discounted at the hurdle rate, it is worth pursuing. If it is negative, it is not worth pursuing. Stated equivalently, the investment is worth pursuing only if its IRR is greater than the companys hurdle rate. Fortunately, Excel has an IRR function that calculates an investments IRRa tough calculation. As with the NPV function, we assume the investment is structured so that there is an initial cash payment at the beginning of year 1 and then regular cash returns at the ends of years 1, 2, and so on. To use the IRR function: Enter the formula =IRR(cashstream,rateguess), where cashstream is a stream of cash flows, where the first (the initial payment) should be negative, and rateguess is an initial guess for the IRR. This seems strange. Why should you have to guess at the answer? It is because Excel calculates the IRR iteratively, starting with your guess. Your actual guess shouldnt make any difference in the final answer except in unusual cases. Try it! Find the IRR for the following investment, using an initial guess of 15%. What does this IRR say about the attractiveness of the investment? (Scroll down to see the answer.)
Cash flows (initial value is a payment) ($100,000) $35,000 $45,000 $40,000 IRR $25,000 $10,000
INDEX Function
The INDEX function is useful for finding the value in a particular cell of a rectangular range. You access this value by the index of the cell you want. Specifically, you specify a row index and a column index. For example, if the range has 10 rows and 20 columns, the index 4,8 indicates row 4 and column 8 of the range. To use the INDEX function:
Chris Albright
Page 38
5/18/2012
Enter the formula =INDEX(range,r_index,c_index), where r_index is an integer (for row) and c_index is an integer (for column). For example, the formula =INDEX(D11:F20,4,2) refers to the value in cell E14, the cell in the fourth row and second column of the range. If range is a single-column range, then the c_index argument can be omitted. In that case, =INDEX(range,r_index) returns the value in row r_index of the range. For example, the formula =INDEX(A11:A20,3) refers to the value in cell A13, the third cell in the range. Similarly, if range is a single-row range, only c_index needs to be included. For example, the formula =INDEX(B10:E10,3) refers to the value in cell D10, the third cell in the range. Try it! Find the unit shipping cost from Plant2 to City3 with a formula in cell B6. Then enter a formula in cell B10 that finds the unit shipping cost from the plant to the city specified in cells B8 and B9. This formula should respond appropriately to whatever plant and city indexes are entered in cells B8 and B9. (Scroll to the right for the answers.)
Unit shipping costs Plant1 Plant2 Plant3 Unit shipping from Plant2 to City3 Plant City Unit shipping cost 1 2 City1 1.25 1.15 1.35 City2 1.35 1.45 1.45 City3 1.55 1.25 1.15
MATCH Function
The MATCH function is handy for finding a cell in a range that matches a given value. It is often used in the following situation. Suppose you have decision variable such as order quantity that needs to chosen so as to maximize some profit. You enter some formulas that link order quantity to the profit. Then you create a data table that finds the profit for a number of possible order quantities. The MATCH function lets you locate the cell in the data table with the smallest profit. To use the MATCH function: Enter the formula =MATCH(value,range,FALSE). This returns the index of the cell in range that matches value. For example, if the match occurs in the third cell of the range, this returns 3. The last argument, FALSE, indicates that we want an exact match. (Actually, FALSE can be replaced by 0 with the same effect.) If there is no exact match, the formula returns an error. The MATCH function can also look for an inexact match by using third argument TRUE. Ill let you look this up in online help. The following spreadsheet indicates how MATCH can be used in conjunction with INDEX. You can imagine that a profit model has led to the table shown, where each order quantity listed leads to the corresponding profit. For this small example, it is obvious that the largest expected profit is $5,640, which corresponds to an order quantity of 300. However, if inputs (not shown) that drive the profit model change, the best order quantity and the corresponding profit could change. We want formulas in cells B9 and B10 to show and the best profit and best order quantity regardless of where they appear in the table.
Chris Albright
Page 39
5/18/2012
Table of profit versus order quantity Order quantity Profit 200 $5,325 250 $5,430 300 $5,640 350 $5,565 400 $5,235 Best profit Best order quantity $5,640 300
The formula in cell B10 is =INDEX(A3:A7,MATCH(B9,B3:B7,0)). The whole purpose of the MATCH function here is to provide the row index for the INDEX function. That is, we know the best order quantity is one of the values in the range A3:A7, and we need to know which one. So we find a match for the maximum value in B3:B7 to the values in B3:B7. In this case, the maximum is the third profit, so the formula is equivalent to =INDEX(A3:A7,3). Try it! The table below shows the profit for each order quantity and each unit stockout cost (along the top). Enter formulas in the range B9:E9 to find the best order quantity for each unit stockout cost. (Scroll down to see the answer.)
Profit for various order quantities (column A) and unit stockout costs (row 3) $2 $3 $4 $5 200 $5,235 $5,175 $5,025 $4,935 250 $5,465 $5,285 $5,190 $5,085 300 $5,355 $5,325 $5,265 $5,100 350 $5,215 $5,195 $5,130 $5,125 400 $5,145 $5,085 $5,015 $5,005 Best order quantities
OFFSET function
The OFFSET function allows you to reference a range (or single cell) relative to another cell. It is hard to appreciate unless you see some examples, so I will present two below. To use the OFFSET function: Enter the formula =OFFSET(cell,r_offset,c_offset,height,width). Here, r_offset and c_offset are integers that can be positive, negative, or zero, and height and width are optional positive integers. If either height and width are missing, they default to 1. This formula returns a reference to a range that has height rows and width columns. To find its upper left cell, start at cell, move r_offset rows down (if positive) or up (if negative), and move c_offset columns to the right (if positive) or the left (if negative). For example the formula =OFFSET(A1,2,3,4,1) returns a reference to the range D3:D6. It is a range with 4 rows and 1 column, and its upper left cell, D3, is offset from cell A1 by going 2 rows down and 3 columns to the right. As another example, the formula =OFFSET(F4,0,-3) refers to a single cell (because the last two arguments are missing), and this single cell is 3 columns to the left of F4, namely, C4. A good example of the OFFSET function appears in the spreadsheet below. Our company sells to a retailer, and the retailer pays a certain number of months later, as indicated by the payment delay (in months) in cell B1. The sales occur as indicated in row 4, but the receipts from the retailer occur 2 months later, as indicated in row 5. Chris Albright Page 40 5/18/2012
2 Oct Nov Dec 3200 4600 5500 Jan 2500 4600 Feb 3300 5500 Mar Apr May Jun 4200 2900 4500 2750 2500 3300 4200 2900
Without the OFFSET function, we could simply put links in the Receipts row that point to sales 2 months earlier. For example, the formula for receipts in January would be =C4. But what if the retailer decides to delay payments by 3 months instead of 2? Then we would need to fix the links in the Receipts row. However, a clever use of OFFSET avoids this updating of links. We use the formula =OFFSET(E4,0,-$B$1) in cell E5 for January and then copy it across row 5 for the other months. This formula says to start in the January sales cell and go a certain number of cells to the left (because of the minus sign), where this number is specified in cell B1. To see how it works, try changing the value in cell B1 to 3 or 1. (What would go wrong if you changed this delay to 4 months? How would you fix it?) Try it! Suppose that a manufacturing company buys raw materials from a supplier. If the cost in any month is $x, the company pays 40% of this cost 1 month from now and the other 60% 2 months from now. Use the OFFSET function to calculate the payments made in January through August, based on the costs through July. These calculated payments should change automatically if you change the inputs in cells B1:B2 and D1:D2. For example, make sure your formulas react correctly if you enter 2 and 3 in cells D1 and D2. (Scroll down to see the answer.)
Percent paid 40% 60% Oct $1,950 when: 1 month from now 2 months from now Dec $4,150 Jan $2,500 Feb $3,350 Mar $2,850
Nov $2,900
Another great use of the OFFSET function is to create a dynamic range name, one that expands or contracts depending on the number of data values in a range. Consider the following spreadsheet, where monthly sales values are entered in column B, and the total of all sales values is calculated in cell E1. Every month, an extra sales value and its month label are appended to the list in columns A and B. We can make the formula in cell E1 automatically adjust to the appended values by using a dynamic range name.
Chris Albright
Page 41
5/18/2012
Total
$17,030
To do this, I selected the Define Name dropdown from the Defined Names group in the Formulas ribbon. In the Name box at the top of the resulting dialog box, I entered Sales as the range name. In the Refers To box at the bottom, I entered the formula =OFFSET(B1,1,0,COUNT(B:B),1). Then I clicked on OK. Finally, I entered the formula =SUM(Sales) in cell E1. Note that COUNT(B:B) refers to the count of all numeric cells in column B. So this OFFSET function refers to a range that starts 1 cell down from cell B1 and has as many rows as there are numeric values in column B. To see how it adjusts, enter a sales value for June in cell B7 and watch how the total changes automatically. Note that COUNT(B:B) counts all of the numeric values in column B, so if there were some other numbers down below sales, they could mess up the logic in the OFFSET function. For example, suppose there were a numeric value in cell B100. Then, given the data above, COUNT(B:B) would return 6, so at that point, the Sales range name would refer to the range B2:B7, that is, 6 cells starting with B2. The moral is that if you want to use dynamic range names, its best not to include junk in the affected columns or rows. Try it! The following spreadsheet has sales by month and by salesperson. We want to sum sales over all months and salespeople in cell B2. Create a dynamic range name that updates when new months are added and when salesperson columns are added or deleted. Then use this range name to sum sales in cell B2. (Scroll across to see answer.)
Total sales Jan-05 Feb-05 Mar-05 Apr-05 May-05 Jun-05 Jul-05 Smith $6,700 $5,800 $5,000 $6,700 $9,400 $6,200 $8,700 Jones $7,400 $8,900 $7,900 $5,800 $7,800 $5,800 $5,300 Wilson $5,800 $5,500 $5,900 $6,000 $6,700 $9,400 $6,900 Donalds $9,000 $7,900 $8,300 $9,700 $8,400 $8,500 $7,500
A great use for dynamic range names is with pivot tables. Suppose you want to base a pivot table on a data set that is likely to expand (or even contract) as time goes on. You can create a dynamic range name such as MyData for the data set. Then when the pivot table wizard asks for the data range, enter MyData. If your data set expands or contracts in the future, all you need to do is click on the Refresh pivot table button (!) to update the pivot table with the newest data. If you show this trick to your colleagues at work, youll be a hero!
Chris Albright
Page 42
5/18/2012