Skip Navigation

[Resolved] Comma – decimal format for numbers (US format)

This support ticket is created 3 years ago. There's a good chance that you are reading advice that it now obsolete.

This is the technical support forum for Toolset - a suite of plugins for developing WordPress sites without writing PHP.

Everyone can read this forum, but only Toolset clients can post in it. Toolset support works 6 days per week, 19 hours per day.

Sun Mon Tue Wed Thu Fri Sat
- 9:00 – 13:00 9:00 – 13:00 9:00 – 13:00 9:00 – 13:00 9:00 – 13:00 -
- 14:00 – 18:00 14:00 – 18:00 14:00 – 18:00 14:00 – 18:00 14:00 – 18:00 -

Supporter timezone: Asia/Karachi (GMT+05:00)

This topic contains 2 replies, has 2 voices.

Last updated by chrisO-12 3 years ago.

Assisted by: Waqar.

Author
Posts
#2260507

Tell us what you are trying to do?
I want to format numbers with comma and decimal separators - US format (1,234,567.89). I see a couple of support tickets that speak to this. How would I do this for a number entry from a custom post type? Prefer to use Toolset block to display the number with comma/decimal format if possible.

https://toolset.com/forums/topic/comma-format/

https://toolset.com/forums/topic/commas-every-third-number-displayed/

Thank you!

#2260691

Hi,

Thank you for contacting us and I'd be happy to assist.

It is recommended to store the unformatted numerical values (for example 1234567.89) as custom field values so that numerical comparisons and arithmetic operations can be performed on them (if and when needed).

You can store the numerical values without the decimal separators in a "number" type custom field and then use a custom shortcode to display the numerical value with decimal separators, on the front-end.

As there is no built-in block to change the format, you can register a new shortcode:
( The code snippet below can be included through either Toolset's custom code feature https://toolset.com/documentation/adding-custom-code/using-toolset-to-add-custom-code/ or through the active theme's "functions.php" file )


// Custom shortcode to display formatted number
function wp_format_number( $atts ) {

	// Attributes
	$atts = shortcode_atts(
		array(
			'number' => '',
		),
		$atts
	);

	return number_format($atts['number'],2,'.',',');

}
add_shortcode( 'wp_format_number', 'wp_format_number' );

And after that, you'll be able to show the formatted value using this new shortcode, through a "Fields and Text" block, like this:


[wp_format_number number='[types field='post-number'][/types]']

Note: In this example the Toolset's field shortcode ( [types field='post-number'][/types] ) is used in the new custom shortcode to convert the numerical value from the custom field with slug "post-number" and show the formatted value ( e.g. 1,234,567.89 ).

I hope this helps and please let me know if you need any further assistance around this.

regards,
Waqar

#2260959

Hi Waqar,

Thank you for the prompt reply! I followed the instructions and it works great!

Regards,
Chris