Solved

How to make thousand separator and decimals in textbox in C#

Posted on 2016-09-27
13
53 Views
Last Modified: 2016-09-27
I'd like to input numbers in a textbox and format it with a thousand separator and two decimals.

I've tried the Masked Edit with a lot of different masks, but I just can't get it to work.

I found something interesting but I have a problem when I put some numbers in the textbox, the cursor comes always to the left ...
Here is the code:
 double text = double.Parse(txt.Text);
                CultureInfo culture = CultureInfo.CreateSpecificCulture("fr-FR");
                

                txt.Text = text.ToString("N0", culture);  

Open in new window

But when I insert in the textbox for example 2500 I got 02 500 while I want 2 500.
Any suggestions ?
Thank you.
0
Comment
Question by:SniperCode Sheva
  • 7
  • 5
13 Comments
 
LVL 69

Expert Comment

by:Éric Moreau
ID: 41818130
can you use 3rd party components like Telerik/DevExpress/Infragistics/... who are doing a much better job to handle this?
0
 
LVL 42

Expert Comment

by:zephyr_hex (Megan)
ID: 41818135
You can use the currency format of ToString()

Example:
Fiddle Demo Here

using System;
					
public class Program
{
	public static void Main()
	{
		decimal myNum = 2500.01m;
		string myString = myNum.ToString("C");
		Console.WriteLine(myString);
		
		double myDouble = 2500.01;
		string myString2 = myDouble.ToString("C");
		Console.WriteLine(myString2);
	}
}

Open in new window

0
 
LVL 42

Expert Comment

by:zephyr_hex (Megan)
ID: 41818150
Or, if you don't want currency and just want the thousands separator with 2 decimal places:
using System;
using System.Globalization;
					
public class Program
{
	public static void Main()
	{
		double myDouble2 = 2500;
		string myString3 = myDouble2.ToString("N",new CultureInfo("en-US"));
		Console.WriteLine(myString3);
	}
}

Open in new window

0
 

Author Comment

by:SniperCode Sheva
ID: 41818151
Hello Zephir, I don't know if you understood my question... I need to seperate the thousand with spaces and when I put some numbers in the textbox, the cursor comes always to the left ...
0
 
LVL 42

Expert Comment

by:zephyr_hex (Megan)
ID: 41818160
You could separate the thousands with spaces by doing a string replace, and replace the comma with a space.

From my last example above, just do:

var myStringWithSpaces = myString3.Replace(",", " ");

Open in new window


To control where the cursor is positioned in the textbox, you will need client side code (i.e.  JavaScript / jQuery), not C#.
0
 

Author Comment

by:SniperCode Sheva
ID: 41818190
Is it possible to put Jquery code in C# ?
0
3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

 
LVL 42

Expert Comment

by:zephyr_hex (Megan)
ID: 41818235
No.  C# is server side code that runs before the page renders.  jQuery is client side code that runs after the server side code is done.  And positioning a cursor requires that the page is loaded, which means it must be done in client side code.
0
 

Author Comment

by:SniperCode Sheva
ID: 41818237
So, there is no a solution ? because when I insert in my textbox 2500 I got 02 500 and if I continue to insert the numbers will be added after the 2 like "22 500"
0
 
LVL 42

Accepted Solution

by:
zephyr_hex (Megan) earned 500 total points
ID: 41818266
Are you inserting text from code behind or actually in the HTML textbox?

And if you use the code I gave you above and assigned myStringWithSpaces to your textbox from codebehind, the textbox would show 2 500.00 or 2 500 00, depending on whether you also replace the decimal with a space.

using System;
using System.Globalization;
					
public class Program
{
	public static void Main()
	{
		double myDouble2 = 2500;
		string myString3 = myDouble2.ToString("N",new CultureInfo("en-US"));
		Console.WriteLine(myString3);
		
		var myStringWithSpaces = myString3.Replace(",", " ");
		Console.WriteLine(myStringWithSpaces);
		
		var myStringWithSpaces2 = myStringWithSpaces.Replace(".", " ");
		Console.WriteLine(myStringWithSpaces2);
	}
}

Open in new window


Updated Fiddle Demo.
0
 

Author Comment

by:SniperCode Sheva
ID: 41818280
I have to mention that I am using textbox !
0
 
LVL 42

Expert Comment

by:zephyr_hex (Megan)
ID: 41818290
I'm confused when you say you want the cursor positioned in the left of the textbox.  That suggests to me that you're talking about the textbox once it's rendered on the client side, and that would require JavaScript or jQuery to position the cursor.  You can not position a cursor from C# because the HTML and cursor don't exist at that point.

If you're talking about assigning your string to a textbox from C#, that's possible.  Just do:
TextBox1.Text = myStringWithSpaces2;
0
 

Author Comment

by:SniperCode Sheva
ID: 41818307
I don't want to put the cursor in the left side... But when I insert in the textbox the cursor automatically go in the left side and I put this code on the key press event...
0
 
LVL 42

Expert Comment

by:zephyr_hex (Megan)
ID: 41818348
If you're using key press event, you really should use jQuery for this.  Otherwise, you're making the user wait for a page lifecycle with every key press.

Here's an example with jQuery:

HTML
<input type="text" id="myTextBox">
<span style="cursor: pointer;">Click here when done</span>

Open in new window


jQuery
$('#myTextBox').blur(function() {
  var val = parseFloat($(this).val()).toLocaleString(undefined, {
    minimumFractionDigits: 2
  });
  var newVal = val.replace(",", " ").replace(".", " ")
  $(this).val(newVal);
});

Open in new window


Example usage:  enter 123456 into the textbox, and then click over to the side.
Result:  123 456 00

Here is a Fiddle Demo.

If that doesn't do it for you, then I'm sorry, but I don't understand what you're trying to accomplish so I'll leave it to someone else to answer.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Entity Framework is a powerful tool to help you interact with the DataBase but still doesn't help much when we have a Stored Procedure that returns more than one resultset. The solution takes some of out-of-the-box thinking; read on!
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
Both in life and business – not all partnerships are created equal. As the demand for cloud services increases, so do the number of self-proclaimed cloud partners. Asking the right questions up front in the partnership, will enable both parties …
As a trusted technology advisor to your customers you are likely getting the daily question of, ‘should I put this in the cloud?’ As customer demands for cloud services increases, companies will see a shift from traditional buying patterns to new…

910 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now