используя Log для решения проблемы ....
static String BytesToString(long byteCount)
{
string[] suf = { "B", "KB", "MB", "GB", "TB", "PB", "EB" }; //Longs run out around EB
if (byteCount == 0)
return "0" + suf[0];
long bytes = Math.Abs(byteCount);
int place = Convert.ToInt32(Math.Floor(Math.Log(bytes, 1024)));
double num = Math.Round(bytes / Math.Pow(1024, place), 1);
return (Math.Sign(byteCount) * num).ToString() + suf[place];
}
Также в c #, но конвертировать должно быть несложно. Также я округлил до 1 десятичного знака для удобства чтения.
По существу, определите количество десятичных знаков в Base 1024, а затем разделите на 1024 ^ десятичных знаков.
И некоторые образцы использования и вывода:
Console.WriteLine(BytesToString(9223372036854775807)); //Results in 8EB
Console.WriteLine(BytesToString(0)); //Results in 0B
Console.WriteLine(BytesToString(1024)); //Results in 1KB
Console.WriteLine(BytesToString(2000000)); //Results in 1.9MB
Console.WriteLine(BytesToString(-9023372036854775807)); //Results in -7.8EB
Edit:
Было указано, что я пропустил math.floor, поэтому я включил его. (Convert.ToInt32 использует округление, а не усечение, и поэтому необходим Floor.) Спасибо за улов.
Edit2:
Было несколько комментариев об отрицательных размерах и 0 байтных размерах, поэтому я обновил, чтобы обработать эти 2 случая.