41

I'm trying not to use the ',' char as a thousand separator when displaying a string, but to use a space instead. I guess I need to define a custom culture, but I don't seem to get it right. Any pointers?

eg: display 1000000 as 1 000 000 instead of 1,000,000

(no, String.Replace() is not the solution I'd like to use :P)

Luk
  • 5,371
  • 4
  • 40
  • 55

5 Answers5

78

I suggest you find a NumberFormatInfo which most closely matches what you want (i.e. it's right apart from the thousands separator), call Clone() on it and then set the NumberGroupSeparator property. (If you're going to format the numbers using currency formats, you need to change CurrencyGroupSeparator instead/as well.) Use that as the format info for your calls to string.Format etc, and you should be fine. For example:

using System;
using System.Globalization;

class Test
{
    static void Main()
    {
        NumberFormatInfo nfi = (NumberFormatInfo)
            CultureInfo.InvariantCulture.NumberFormat.Clone();
        nfi.NumberGroupSeparator = " ";

        Console.WriteLine(12345.ToString("n", nfi)); // 12 345.00
    }
}
Jon Skeet
  • 1,421,763
  • 867
  • 9,128
  • 9,194
9

Create your own NumberFormatInfo (derivative) with a different thousand separator.

Lucero
  • 59,176
  • 9
  • 122
  • 152
7

There's a slightly simpler version of Jon Skeet one :

using System;
using System.Globalization;

class Test
{
    static void Main()
    {
        NumberFormatInfo nfi = new NumberFormatInfo {NumberGroupSeparator = " ", NumberDecimalDigits = 0};

        Console.WriteLine(12345678.ToString("n", nfi)); // 12 345 678
    }
}

And the 'nfi' initialization could be skipped and put directly as parameter into the ToString() method.

Invvard
  • 1,497
  • 2
  • 15
  • 20
3

Easiest way...

num.ToString("### ### ### ### ##0.00")
Pranay Rana
  • 175,020
  • 35
  • 237
  • 263
Gordon Bell
  • 13,337
  • 3
  • 45
  • 64
  • 6
    Although this works it will actually produce spaces in front of the number. For example the number 1 would have 4 spaces in front of it. So at least you will have to trim it. I think the best solution is to adjust the NumberFormatInfo if you want to override the Culture default format. – Johncl Oct 04 '11 at 07:20
0

I wanted to

  • have space as a thousand separator,
  • have up to two decimals and
  • optionally be negative.

This code solves it:

var regex = new Regex(@"(^|(?<=-))\s*");
var format = "### ### ### ### ##0.##";
decimal number = 123456789.54m;
var str = regex.Replace(number.ToString(format), ""); // str = "123 456 789.54"

Here are examples of how this behaves for various numbers:

regex.Replace(0m.ToString(format), "")
"0"
regex.Replace(123m.ToString(format), "")
"123"
regex.Replace(123456789m.ToString(format), "")
"123 456 789"
regex.Replace(123456789.1m.ToString(format), "")
"123 456 789.1"
regex.Replace(123456789.12m.ToString(format), "")
"123 456 789.12"
regex.Replace(123456789.1234m.ToString(format), "")
"123 456 789.12"
regex.Replace((-123456789.1234m).ToString(format), "")
"-123 456 789.12"
regex.Replace((-1234m).ToString(format), "")
"-1 234"
regex.Replace((-1m).ToString(format), "")
"-1"
Daniel Jonsson
  • 3,261
  • 5
  • 45
  • 66