88

I am working in progress bar concept in ASP.NET MVC 2. Here i have a DropDownList which has 10 values. i want to calculate the percentage for progress bar, e.g. 10 values from DropDownList and i am having a query which returns the value 2. so, out of 10 values i am getting 2. "20 % completed" should be displayed.. How to do this calculation

abatishchev
  • 98,240
  • 88
  • 296
  • 433
RobinHood
  • 2,367
  • 11
  • 46
  • 73

8 Answers8

108

Using Math.Round():

int percentComplete = (int)Math.Round((double)(100 * complete) / total);

or manually rounding:

int percentComplete = (int)(0.5f + ((100f * complete) / total));
ataravati
  • 8,891
  • 9
  • 57
  • 89
Sogger
  • 15,962
  • 6
  • 43
  • 40
  • So, `complete` and `total` should be `int` or `double`? Thanks. – Si8 Jul 14 '16 at 14:40
  • It doesn't matter actually if you use it exactly as written here. Proving this statement is an exercise left to the reader :) – Sogger Jul 15 '16 at 18:15
  • 1
    you should never use a floating point number (ie double) for money – Stuart Dobson Sep 26 '17 at 09:53
  • 9
    If you are doing anything with money I would really, really hope you weren't googling 'how to calculate percentage' :P If you are, please do more reading on floating point precision, banker's rounding, and especially 'professional liability insurance' – Sogger Feb 24 '18 at 20:00
  • @Sogger I am actually working with money and transactions and came here. I use decimal values myself, but wanted to be sure the percentage calculation would be correct. – I try so hard but I cry harder Nov 16 '22 at 09:03
98

(current / maximum) * 100. In your case, (2 / 10) * 100.

Nicolas Repiquet
  • 9,097
  • 2
  • 31
  • 53
52

With C# String formatting you can avoid the multiplication by 100 as it will make the code shorter and cleaner especially because of less brackets and also the rounding up code can be avoided.

(current / maximum).ToString("0.00%");

// Output - 16.67%

Habeeb
  • 7,601
  • 1
  • 30
  • 33
16

Mathematically, to get percentage from two numbers:

percentage = (yourNumber / totalNumber) * 100;

And also, to calculate from a percentage :

number = (percentage / 100) * totalNumber;
OrionMD
  • 389
  • 1
  • 7
  • 13
Sonador
  • 484
  • 5
  • 13
14

You can hold onto the percentage as decimal (value \ total) and then when you want to render to a human you can make use of Habeeb's answer or using string interpolation you could have something even cleaner:

var displayPercentage = $"{(decimal)value / total:P}";

or

//Calculate percentage earlier in code
decimal percentage = (decimal)value / total;
...
//Now render percentage
var displayPercentage = $"{percentage:P}";
Bronumski
  • 14,009
  • 6
  • 49
  • 77
4

Bear in mind that you may need to cast one of the numbers to double if you have two ints

(double)i / events.Count * 100
Christian Findlay
  • 6,770
  • 5
  • 51
  • 103
0

In my case, I set two ints, and trying to calculate the percentage, and always get 0;

my code (before)

int Ff_Crm_Count = Ff_Crm.Count();
int Unfollowed_Ff_Crm_Count = Unfollowed_Ff_Crm.Count();
int The_Percentage = (Unfollowed_Ff_Crm_Count / Ff_Crm_Count) * 100);

after doing research (after)

double Ff_Crm_Count = Ff_Crm.Count();
double Unfollowed_Ff_Crm_Count = Unfollowed_Ff_Crm.Count();
double The_Percentage = Math.Round((double)((Unfollowed_Ff_Crm_Count / Ff_Crm_Count) * 100),2);
Grigory Zhadko
  • 1,484
  • 1
  • 19
  • 33
Nick Zhou
  • 11
  • 3
0

//For other people

If you need calculate using negative numbers:

double minValue = -100;
double value = 30;
double maxValue = 100;
dobule perc = (value - minValue) / (maxValue - minValue);
Console.WriteLine((perc * 100) + "%");
Yotic
  • 136
  • 1
  • 8