Formeln för att beräkna procentuell varians i Excel fungerar utmärkt i de flesta fall. Men när referensvärdet är ett negativt värde bryts formeln ner.
Föreställ dig till exempel att du startar ett företag och räknar med att gå med förlust det första året. Så du ger dig själv en budget på negativa $10 000. Föreställ dig nu att du efter ditt första år faktiskt tjänade pengar och tjänade 12 000 $. Att beräkna den procentuella skillnaden mellan dina faktiska intäkter och budgeterade intäkter skulle ge dig –220 %. Du kan prova det på en miniräknare. 12 000 minus –10 000 dividerat med –10 000 är lika med –220 %.
Hur kan du säga att din procentuella avvikelse är –220% när du klart tjänat pengar? Tja, problemet är att när ditt referensvärde är ett negativt tal, inverterar matematiken resultaten, vilket gör att siffror ser galna ut. Detta är ett verkligt problem i företagsvärlden där budgetar ofta kan vara negativa värden.
Fixningen är att utnyttja ABS-funktionen för att negera det negativa riktmärket:
=(C4-B4)/ABS(B4)
Figuren använder den här formeln i cell E4, och illustrerar de olika resultaten du får när du använder standardformeln för procentvarians och den förbättrade procentuella variansformeln.
Excels ABS-funktion returnerar det absoluta värdet för alla tal du skickar till den. Att skriva in =ABS(-100) i cell A1 skulle returnera 100. ABS-funktionen gör i princip vilket tal som helst till ett icke-negativt tal. Om du använder ABS i den här formeln förnekas effekten av det negativa riktmärket (den negativa budgeten på 10 000 i exemplet) och returnerar den korrekta procentuella variansen.
Du kan säkert använda denna formel för alla dina procentuella variansbehov; det fungerar med alla kombinationer av positiva och negativa tal.
Alternativa beräkningar för procentuell förändring med negativa tal
Här är några sätt att testa om det finns ett negativt tal och ge ett alternativt resultat.
Metod #1: Inget resultat för negativa
Det första vi kan göra är att kontrollera om någon av siffrorna är negativa och sedan visa lite text för att tala om för läsaren att en procentuell ändringsberäkning inte kunde göras.
Följande formel gör detta med en OM-funktion och MIN-funktion.
=OM(MIN(gammalt värde, nytt värde)<=0,"--",(nytt värde/gammalt värde)-1)
Så här fungerar formeln:
Det logiska testet av OM-funktionen (MIN(gammalt värde, nytt värde)<=0) hittar minimum av de två värdena och testar om värdet är mindre än eller lika med noll. Resultatet blir antingen TRUE eller FALSE.
Om resultatet är SANT finns det ett negativt tal (eller noll). I det här fallet kan vi visa lite text för att berätta för läsaren. Det här kan vara vad du vill. Jag använde bara två streck "–". Du kan också få den att returnera ett N/A-fel med funktionen NA() eller någon annan text som låter läsaren veta att den procentuella förändringen inte kunde beräknas.
Om resultatet är FALSK, används formeln för procentuell förändring för att returnera den procentuella förändringen på de två positiva talen.
Den här formeln hanterar också divideringen med noll (#DIV/0!), så vi behöver inte slå in den i IFERROR-funktionen.
Metod #2: Visa positiv eller negativ förändring
Wall Street Journal-guiden säger att dess resultatrapporter visar ett "P" eller "L" om det finns ett negativt tal och företaget redovisar vinst eller förlust.
Vi skulle kunna använda samma metod för att berätta för våra läsare om förändringen var positiv (P) eller negativ (N) när något av värdet är negativt.
Följande formel testar detta med en extra OM-funktion.
=OM(MIN(gammalt värde, nytt värde)<=0,OM((nytt värde - gammalt värde)>0,"P","N"),(nytt värde/gammalt värde)-1)
Så här fungerar formeln:
Vi börjar med samma logiska test för att avgöra om det finns ett negativt värde med hjälp av MIN-funktionen.
En andra OM-funktion används sedan för att avgöra om förändringen från gammalt till nytt är positivt eller negativt.
IF((nytt värde – gammalt värde)>0,”P”,”N”)
Denna IF-sats returnerar ett "P" för en positiv förändring och ett "N" för en negativ förändring.
Om båda siffrorna är positiva används formeln för procentuell förändring för att visa resultatet.