Python Add Comma Into Number String

PythonString

Python Problem Overview


Using Python v2, I have a value running through my program that puts out a number rounded to 2 decimal places at the end:

like this:

print ("Total cost is: ${:0.2f}".format(TotalAmount))

Is there a way to insert a comma value every 3 digits left of the decimal point?

Ie: 10000.00 becomes 10,000.00 or 1000000.00 becomes 1,000,000.00

Thanks for any help.

Python Solutions


Solution 1 - Python

In Python 2.7 and 3.x, you can use the format syntax :,

>>> total_amount = 10000
>>> print("{:,}".format(total_amount))
10,000
>>> print("Total cost is: ${:,.2f}".format(total_amount))
Total cost is: $10,000.00

This is documented in PEP 378 -- Format Specifier for Thousands Separator and has an example in the Official Docs "Using the comma as a thousands separator"

Solution 2 - Python

if you are using Python 3 or above, here is an easier way to insert a comma:

First way

value = -12345672
print (format (value, ',d'))

or another way

value = -12345672
print ('{:,}'.format(value)) 

Solution 3 - Python

You could use locale.currency if TotalAmount represents money. It works on Python <2.7 too:

>>> locale.setlocale(locale.LC_ALL, '')
'en_US.utf8'
>>> locale.currency(123456.789, symbol=False, grouping=True)
'123,456.79'

Note: it doesn't work with the C locale so you should set some other locale before calling it.

Solution 4 - Python

'{:20,.2f}'.format(TotalAmount)

Solution 5 - Python

This is not particularly elegant but should work too :

a = "1000000.00"
e = list(a.split(".")[0])
for i in range(len(e))[::-3][1:]:
    e.insert(i+1,",")
result = "".join(e)+"."+a.split(".")[1]

Solution 6 - Python

A function that works in python2.7+ or python3.1+

def comma(num):
    '''Add comma to every 3rd digit. Takes int or float and
    returns string.'''
    if type(num) == int:
        return '{:,}'.format(num)
    elif type(num) == float:
        return '{:,.2f}'.format(num) # Rounds to 2 decimal places
    else:
        print("Need int or float as input to function comma()!")

Solution 7 - Python

another way very short is

value = -122212123.12
print(f"{value:,}")

Solution 8 - Python

The above answers are so much nicer than the code I was using in my (not-homework) project:

def commaize(number):
	text = str(number)
	parts = text.split(".")
	ret = ""
	if len(parts) > 1:
		ret = "."
		ret += parts[1] # Apparently commas aren't used to the right of the decimal point
	# The -1 offsets to len() and 0 are because len() is 1 based but text[] is 0 based
	for i in range(len(parts[0]) - 1,-1,-1):
		# We can't just check (i % 3) because we're counting from right to left
		#  and i is counting from left to right. We can overcome this by checking
		#  len() - i, although it needs to be adjusted for the off-by-one with a -1
		# We also make sure we aren't at the far-right (len() - 1) so we don't end
		#  with a comma
		if (len(parts[0]) - i - 1) % 3 == 0 and i != len(parts[0]) - 1:
			ret = "," + ret
		ret = parts[0][i] + ret
	return ret

Solution 9 - Python

Started learning Python about 5 hours ago, but I think I came up with something for integers (sorry, couldn't figure out floats). I'm in high school, so big chance the code could be way more efficient; I just made something from scratch that made sense to me. If anyone has any ideas on how to improve with ample explanation of how it works, let me know!

# Inserts comma separators
def place_value(num):
    perm_num = num  # Stores "num" to ensure it cannot be modified
    lis_num = list(str(num))  # Makes "num" into a list of single-character strings since lists are easier to manipulate
    if len(str(perm_num)) > 3:
        index_offset = 0  # Every time a comma is added, the numbers are all shifted over one
        for index in range(len(str(perm_num))):  # Converts "perm_num" to string so len() can count the length, then uses that for a range
            mod_index = (index + 1) % 3  # Locates every 3 index
            neg_index = -1 * (index + 1 + index_offset)  # Calculates the index that the comma will be inserted at
            if mod_index == 0:  # If "index" is evenly divisible by 3
                lis_num.insert(neg_index, ",")  # Adds comma place of negative index
                index_offset += 1  # Every time a comma is added, the index of all items in list are increased by 1 from the back
        str_num = "".join(lis_num)  # Joins list back together into string
    else:  # If the number is less than or equal to 3 digits long, don't separate with commas
        str_num = str(num)
    return str_num

Solution 10 - Python

I feel comfortable using like this in python:

input_value=float(input())
print("{:,}".format(input_value))

Solution 11 - Python

Latest versions of python use f-strings. So you can do this:

print("Total cost: {total_amount:,}

As long as total_amount is a not a string. Otherwise you'd need to cast it to a number type first like so:

print("Total cost: {Decimal(total_amount):,}

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionThe WooView Question on Stackoverflow
Solution 1 - PythonSven MarnachView Answer on Stackoverflow
Solution 2 - PythoncooldealView Answer on Stackoverflow
Solution 3 - PythonjfsView Answer on Stackoverflow
Solution 4 - PythonPeter KellyView Answer on Stackoverflow
Solution 5 - PythonThR37View Answer on Stackoverflow
Solution 6 - Pythondnaman7View Answer on Stackoverflow
Solution 7 - PythonTài HatranducView Answer on Stackoverflow
Solution 8 - PythonQBFreakView Answer on Stackoverflow
Solution 9 - PythonDrake JohnsonView Answer on Stackoverflow
Solution 10 - PythonFahimFBAView Answer on Stackoverflow
Solution 11 - PythonEnterPasswordView Answer on Stackoverflow