This is part 5 of 6 on Profit & Loss Reporting using Excel series, written by Yogesh
Data sheet structure for Preparing P&L using Pivot Tables
Preparing Pivot Table P&L using Data sheet
Adding Calculated Fields to Pivot Table P&L
Exploring Pivot Table P&L Reports
Quarterly and Half yearly Profit Loss Reports in Excel
Budget V/s Actual Profit Loss Report using Pivot Tables
This is continuation of our earlier post Exploring Profit Loss Pivot Reports.
We have learned how to change our P&L report on various data elements. We have seen how the P&L report can be changed with just few clicks.
In this post we will be learning some grouping tricks in PivotTables. We will cover grouping of dates, text fields and numeric fields. You will need to start with Monthly P&L report prepared in previous post.
Grouping Profit Loss Report based on Dates
- Right click on date field > Choose Group > Choose Quarters from dates grouping dialog box > click OK.
- Tutorial: Grouping Dates in Pivot Tables.
Once done your quarterly P&L is ready, you can still filter it on any other filed. Checkout screen cast for quarterly P&L prepared and filtered on City filed to make Quarterly P&L for Amritsar City.
Not only this, you can also drag grouped data to page area and Geography field to column area of PivotTable. Now you can filter it on Qtr1 to make Geography wise P&L for Qtr1.
[Click here to see how to do this]
This one is simple as it groups January to March period as Qtr1, April to June as Qtr2 and so on.
Grouping Dates based on Apr-Mar Financial Year
Most of the Indian companies follow April to March as Financial Year. They start with April to June as Qtr1 and finish with January to March as Qtr4. You will need different steps if you want make April to June as Qtr1 and January -March as Qtr4.
In our Data we have January 2009 to March 2009 period as Qtr 4 of 08-09 Financial Year. Grouping steps are as under
- Select January to March month columns > right click on selected columns > Choose Group.
- Rename Group1 as Q4.08-09
- Follow similar steps to Group April 2009 to June 2009 as Q1.09-10 and so on.
- [Click here to see how to do this]
- Drag the grouped field out of PivotTable in case you want to remove grouping.
The final report looks like this:
Many companies follow different Financial Year. In case your company follows May to April as Financial Year, you can select May June and July months and group them as Qtr1. You have the flexibility to select particular periods and group them. You can input name of the group as you want.
In similar way you can group 6 months to make half yearly Profit Loss Report in Excel.
Grouping Profit Loss Report Based on Text Fields
You can group data on text fields. In Geography wise P&L you can group South and East column to make P&L for South East.
You can select non consecutive columns :- Click on East column > Press Ctrl > Click on South column while you keep Ctrl key pressed. You will see that you have both the columns selected.
Select East and South Column > Right Click > Choose Group > Rename Group1 as South East.
Drag the grouped field out of PivotTable in case you want to remove grouping.
[Click here to see how this is done]
Grouping Profit Loss Report based on Numbers
You can also group data on numeric fields. We will make a PivotTable P&L grouping stores based on their size. Prepare P&L on store sizes by dropping store area field into column area of PivotTable.
Right Click on Store Area filed > Choose Group > Enter grouping parameters in Group dialog box > Click OK
You have the P&L for stores grouped based on their size.
Putting it all together – Creating a Custom Profit Loss Report Layout in Excel:
You can explore your PivotTable P&L in any combinations discussed in this post and our previous post.
So how about making South East Geography P&L for Q1 only of stores sized 4000 – 4999, like this?
It is just few clicks and your P&L will be ready , watch out screencast.
[this is a heavy screencast, so click thru if you want to watch it].
Dealing with “Cannot group that selection” error:
While grouping fields in PivotTable you may get a message saying “Cannot group that selection”. This happens due to blank date / number field or text in date / number field. You may have some blank rows in the data causing this problem. Some time you may have second copy of date field shown as Month2 or date2. This is duplicate field created in PivotTable which is already grouped. You will need to un-group this before grouping date filed again differently if required.
Download Excel file with all these example Pivot Reports:
Download Profit Loss Report Excel file and practice all these tricks on your own. [mirror download location]
What Next?
In the next part of this series, learn how to prepare budget vs. actual profit-loss reports.
Meanwhile, make sure you have read the first 4 parts of this series – Data sheet structure, Preparing P&L Pivot Table, Adding Calculated Fields and Exploring Profit Loss Report Pivot
Also check out the Excel Pivot Tables – Tutorial, Pivot Table Tricks, Grouping Dates in Pivot Reports articles to get more ideas.
Added by PHD:
- Say thanks if you like the idea and want to learn more.
- Please share your feedback and ideas for this series using comments. Yogesh and I will reply to your questions.
- Sign-up for PHD E-mail newsletter because you will get updates as new posts go online.

24 Responses to “Free Excel Risk Map Template”
Why didn't you include the mitigation or risk IDs in the chart?
You can easily add such detail by modifying the TEXTJOIN function. Another way to use them is to add a slicer to highlight all risks that have a specific mitigation strategy or team member assigned to them. I left out those bits fto keep the article short.
I tried adding a slicer filter for the mitigation step but the TEXTJOIN is not affected by it. I added a helper column called "Visible" using the AGGREGATE function but I am unable to think of a method to pass that on to the map.
Could you please help, Chandoo?
Thanks
Never mind. I got it working. 🙂
Apologies, I didn't thank you for the file to begin with.
Great concept. thanks!
Awesome.. good to hear that Rajesh and of course you are welcome 🙂
Hello everyone,
Another amazing tutorial, great content and tips! My question is about slicers. How do you add slicers to this matrix? I've added 2 columns in my workbook table (Work Stream and Project Name) and I want to be able to filter (slice) the matrix on Project Name, but having some trouble with this. The slicer works fine in the data table, but how do I connect it to the risk matrix, so that only risk titles show up for the selected project?
Many thanks in advance for your guidance,
MyvJ
Can you create a sheet in live stock market data price change with profit and loss graph with time. which could indicate live profit and loss in each time frame 5minute, 10 minute, 15 minute, 30minute, hourly with some modifications
Hi
I've tried to get your formula to work, but likelihood / impact 1/1 does not seem to work.
Hi Chandoo
Awesome instructions! Thank you so much, this really helped me.
I was wondering if it would be possible to list the Risk ID number along with the Risk Title with a dash in between, rather than a bullet point? I have had a try at this but I keep getting a #VALUE error. I can see it's wrong but can't figure out what it should be instead. If you have time do you mind letting me know what I'm doing wrong?
{=" - " & TEXTJOIN(CHAR(10)&" - ",TRUE,
IF(RiskRegister[Likelihood]=$A17,IF(RiskRegister[Consequence]=F$3,CONCAT(RiskRegister[ID],RiskRegister[Risk Title]),""),""))}
Thank you!
Sally
Hey Sally, You are welcome.
I think the CONCAT inside TEXTJOIN is the culprit. Try this and hopefully you should see the ID too.
{=" - " & TEXTJOIN(CHAR(10)&" - ",TRUE,
IF(RiskRegister[Likelihood]=$A17,IF(RiskRegister[Consequence]=F$3,RiskRegister[ID]&RiskRegister[Risk Title],""),""))}
Hi Chandoo
You're a legend! Thank you so much! I had to make a minor tweak but otherwise it worked perfectly. Here is the tweaked version in case it helps anyone else:
=TEXTJOIN(CHAR(10),TRUE,
IF(RiskRegister[Likelihood]=$A8,IF(RiskRegister[Consequence]=C$3,RiskRegister[ID]&" - "&RiskRegister[Risk Title],""),""))
Thank you again!
Hi, Im not able to change the formula when trying to add risk Id instead of bullet point.
trying this: ="• "&TEXTJOIN(CHAR(10)&"• ";TRUE;IF(risks[Probability of Occurance *]=$C5;IF(risks[Severity of potential Impact *]=H$8;risks[Risk ID]&". "[Title *];"");""))
Cant see any solution on this.
thankful for help
Hi Chandoo,
This is perfect - One quick question, How can I add a hyperlink to the risks - So that I can click on the particular risk and it takes me to the actual row of that item.
Many thanks in advance.
HI Chandoo,
Is there a way to only display filtered item. Once the list gets big, it's hard to see all risk.
Kind regards,
SinYen
Hi Chandoo,
Quick question
1) Is there a way to remove duplicates within each risk block?
2) Is there a way to have the results in the chart update based on a filter or slicer?
Thanks a lot
Hi Chandoo,
The risk map is a brilliant tool, and I wanted to the risk map to only show Open risks. How can I do that?
Just found this today as I am making a risk matrix as well. I got the formula to work with this, where a risk score is above 30. Risk score = probability*impact*modifier.
So this works flawlessly, ="- "&TEXTJOIN(CHAR(10)&"- ",TRUE,IF('Risk tracker'!G4:G27>=30,IF(Table1[Urgency]="Now",'Risk tracker'!A4:A27,""),""))
I am trying to find a range now. Risk score in between 21-29. I tried using the AND function, but I couldnt get it to work. Is there anyway to get this formula to work with a range as mentioned above?
Thanks Eric.
You can't use AND() as it is not able to return arrays. You can try below formula.
="- "&TEXTJOIN(CHAR(10)&"- ",TRUE,IF(('Risk tracker'!G4:G27>=21)*('Risk tracker'!G4:G27<=29),IF(Table1[Urgency]="Now",'Risk tracker'!A4:A27,""),""))
Hello, this template is nice, thank you but im facing a problem when I need to find a range of impact. I cant figure out how..
My actual form is "="• "&TEXTJOIN(CHAR(10)&"• ";TRUE;IF(Table1[Impact]=A8;Table1[Title];"");"")"
Where A8 is number "1" so this formula finds everything with impact 1 and shows the titles.
What I need to get is a range so,
A8 is "1" and A9 is "2" and I need the formula to find all titles which impact is between 1 and 2.
I tried the AND function and so on, nothing worked..
Can you help me please?
i tried everything in your video in the end i only get the bullet... please guide me through
Sorted it... i was flash filling the other cells and it took other columns...
i do have another question though... how can i use slicers to filter the content of the matrix, so that it'll show only the departments i select?
slicer is working fine with the table, but the matrix still shows all the results
Just want to thank you for this.
It is awesome.
Hello everyone,
I think I accidentally nested my question in another thread. Apologies!
This is another amazing Excel tutorial, with great content and tips! My question is about slicers. How do you add slicers to this matrix? I've added 2 columns in my workbook table (Work Stream and Project Name) and I want to be able to filter (slice) the matrix on Project Name, but having some trouble with this. The slicer works fine for the data table, but how do I connect it to the risk matrix, so that only risk titles show up for the selected project?
Many thanks in advance for your guidance,
MyvJ
This is another amazing Excel tutorial! My question is about slicers. How do you add slicers to this matrix? Please advise