Often, you may have decimal values in your product prices. This is quite common in case of an online grocery store where prices are determined by the weight of the vegetables:
Decimal Separator:
In many countries, the decimal separator is represented by a dot (.). However, this is not true for a lot of other countries such as Spain, South Africa, Brazil, Sweden, China and 70 other countries where the decimal separator is a comma.
Countries like Brazil use the dot (.) to sometimes separate thousands. For example, twelve thousand and five hundred is written not as “12,500” but as “12.500” or even “12 500”.
Prices thus need to be displayed differently while designing a store for a particular audience or nationality. In this post, we will see how we can replace decimal points with commas or spaces in WooCommerce.
There are two ways of doing this in- either directly through WooCommerce Settings or through the code editor.
1. Changing the Decimal Separator through WooCommerce Settings
Hover your mouse over the WooCommerce label in your WordPress dashboard, and click on Settings. In WooCommerce->Settings, the General tab shows the following as you scroll down:
Here, you can change the value of “Decimal Separator” from “.” to “,”
Doing this and clicking on “Save Changes” will display the decimal point as a comma:
In this way, you can use any separator of your choice.
2. Changing the Decimal Separator through the code editor
While WooCommerce provides a direct way to change the decimal separator, learning to do this via code is useful.
In this example, we will demonstrate how to replace the decimal point with a space using the code editor.
There is a small code snippet that you can insert in the functions.php file of your child theme to do just this.
(To know why we edit the functions.php of the child theme and not directly the functions.php file, read this post.)
Code Snippet:
add_filter( 'wc_price', 'woo_hide_decimal_point', 10, 4 ); function woo_hide_decimal_point( $return, $price, $args, $unformatted_price ) { $unit = intval( $price ); $decimal = sprintf( '%02d', ( $price-$unit ) * 100 ); return sprintf( '%s %d %s', get_woocommerce_currency_symbol(), $unit, $decimal ); }
And the result is that the decimal point is removed and replaced by a space:
Note: The code will work only after you set the decimal separator to a “.” in WooCommerce->Settings.
You can replace the space with a comma in a similar way by changing the code just a little bit.
add_filter( 'wc_price', 'woo_replace_decimal_point', 10, 4 ); function woo_replace_decimal_point( $return, $price, $args, $unformatted_price ) { $unit = intval( $price ); $decimal = sprintf( '%02d', ( $price-$unit ) * 100 ); return sprintf( '%s %d,%s', get_woocommerce_currency_symbol(), $unit, $decimal ); }
Why it’s better to use code snippets over WooCommerce->Settings to replace the decimal separator:
Using the code editor as opposed to WooCommerce->Settings to replace decimal points has many advantages.
One is that you can format the price the way you want to. If you notice in the image above, the price has a space after the currency symbol. This space is missing in the first screenshot of this post where the decimal point has been replaced through WooCommerce->Settings.
By using code snippets, you can also display the decimal portion of the price in different styles by inserting HTML tags such as <b>,<u>,<i>,<sup>,<sub> and many more.
If you would like to know how you can display the decimal value as a superscript or a subscript, read this post.
I tried with this code and worked properly but for variation products the price on the frontend was disappeared. Any solution for this? check the attachment.
also I’m facing currency issue which same symbol for both languages ( It must be for English “SAR” and for arabic “ر.س”
So please we need your help…
Best Regards.
Hi ,
I have tested the code with WooCommerce version 9.1.1 and it works well for both simple and variable products, as shown in this screenshot- https://screenrec.com/share/2RKk5TnYiP. Please try switching to a default WordPress theme and deactivating other plugins to check for conflicts.
Regarding the currency symbol issue, if the same symbol appears in both English and Arabic, it might be due to an issue with any multilingual plugins you have installed. If the issue persists, provide details about the multilingual customization you have done to your site, so that we can help resolve it.
Thanks for quick response. I tried with the below code, add_filter( ‘wc_price’, ‘woo_format_decimal_value’, 10, 4 ); function woo_format_decimal_value( $return, $price, $args, $unformatted_price ) { $unit = intval( $price ); $decimal = sprintf( ‘%02d’, ( $price-$unit ) * 100 ); return sprintf( ‘%s %d.%s’, get_woocommerce_currency_symbol(), $unit, $decimal ); } I found one issue for the above code that (if the like 3000 it appears 3.00) the main issue I’m facing is the decimal and thousand separators in Arabic language (img Attached) because of the Polylang plugin which i use but I didn’t find solution for that, so please is there any… Read more »
The code provided in this post works fine with the default currency options configured in the WooCommerce setup. For your specific requirement to display decimal and thousand separators correctly in Arabic and other multilanguages, I would recommend trying out a free plugin called “Price Based on Country for WooCommerce.” Hope this helps you out!
I tried with this plugin but still same issue of decimal & thousand separators with Arabic language
so thanks so much and I will try till find the solution.
I have set dot as the decimal seperator in Woocommerce general settings. Inspite of this the prices on the frontend displays comma as decimal seperator.
I want to display dot as the seperator. Any fix for this?
Hi Alex,
I tried to reproduce the issue on my site and both the method of default WooCommerce settings to set the separator and the code is working fine in my updated WooCommerce version (8.8.2) and Storefront theme. The issue might be due to conflict with any other currency plugin if you have so. Please try switching to a default WordPress theme and deactivating other plugins to check if there is a theme/plugin conflict. If the issue persists, you can provide additional details for further assistance.