แสดงทศนิยมในรูปแบบทางวิทยาศาสตร์


160

ฉันจะแสดงสิ่งนี้ได้อย่างไร:

ทศนิยม ('40800000000.00.00000000000000') เป็น '4.08E + 10'

ฉันเคยลองแล้ว:

>>> '%E' % Decimal('40800000000.00000000000000')
'4.080000E+10'

แต่มันมี 0 ที่พิเศษเหล่านั้น


3
การโพสต์สองครั้งคุณสามารถใช้หัวข้อนี้เมื่อคุณเพิ่งเริ่มต้น: stackoverflow.com/questions/6913166/ …
Samuele Mattiuzzo

13
ไม่เลย ฉันต้องการแยกคำถามนี้ออกเป็นคำถามง่าย ๆ (วิธีทำใน Python) และคำถามที่ยากและคลุมเครือซึ่งฉันสงสัยว่าใครจะตอบได้ (จะทำอย่างไรใน Django) สังเกตว่านี่มีคำตอบอยู่แล้ว ตอนนี้ฉันตอบไปครึ่งทางแล้วแทนที่จะเป็น 0% ถ้าฉันโพสต์ด้วยกัน นอกจากนั้นการแยกคำถามทำให้ผู้คนสามารถค้นหาคำตอบได้ง่ายขึ้น E. , ถ้าหาก Bob กำลังค้นหาคำถามการจัดรูปแบบทศนิยมเขาอาจข้ามการแสวงหา SO กับ Django ในชื่อ
เกร็ก

ใช่มันเป็นเพียงเพื่อความสนใจของฉัน: P มันง่ายกว่าที่จะติดตามหนึ่งกระทู้ โดยพื้นฐานแล้วมันคล้ายกับคำตอบของฉัน (เฉพาะเจาะจงมากขึ้น) ฉันหวังว่าจะได้คำตอบ django ด้วย btw
Samuele Mattiuzzo

คำตอบ:


157
from decimal import Decimal

'%.2E' % Decimal('40800000000.00000000000000')

# returns '4.08E+10'

ใน '40800000000.00000000000000' ของคุณมีค่าศูนย์ที่สำคัญมากกว่าซึ่งมีความหมายเหมือนกับตัวเลขอื่น ๆ นั่นเป็นเหตุผลที่คุณต้องบอกอย่างชัดเจนว่าคุณต้องการหยุดที่ใด

หากคุณต้องการลบเลขศูนย์ต่อท้ายทั้งหมดโดยอัตโนมัติคุณสามารถลอง:

def format_e(n):
    a = '%E' % n
    return a.split('E')[0].rstrip('0').rstrip('.') + 'E' + a.split('E')[1]

format_e(Decimal('40800000000.00000000000000'))
# '4.08E+10'

format_e(Decimal('40000000000.00000000000000'))
# '4E+10'

format_e(Decimal('40812300000.00000000000000'))
# '4.08123E+10'

22
นอกจากนี้แม้ว่าจะformat % valuesยังมีการใช้งานไวยากรณ์แม้ในไลบรารีมาตรฐาน Python 3 แต่ฉันเชื่อว่ามันเลิกใช้งานทางเทคนิคใน Python 3 หรืออย่างน้อยก็ไม่ใช่วิธีการจัดรูปแบบที่แนะนำและไวยากรณ์ที่แนะนำปัจจุบันเริ่มต้นด้วย Python 2.6 จะเป็น'{0:.2E}'.format(Decimal('40800000000.00000000000000'))( หรือ'{:.2E}'ใน Python 2.7+) แม้ว่าจะไม่เป็นประโยชน์อย่างยิ่งสำหรับสถานการณ์นี้เนื่องจากตัวอักขระเพิ่มเติมสำหรับการทำงานที่ไม่ได้เพิ่มstr.formatจะช่วยให้การผสม / การจัดเรียงใหม่ / การใช้ reutilizing ของอาร์กิวเมนต์รูปแบบที่ซับซ้อนมากขึ้น
JAB

หลาม 3 เกี่ยวกับอะไร?
Charlie Parker

4
@CharlieParker formatใช้ มันมากขึ้นมีชีวิตชีวา
Mateen Ulhaq

120

นี่คือตัวอย่างการใช้format()ฟังก์ชั่น:

>>> "{:.2E}".format(Decimal('40800000000.00000000000000'))
'4.08E+10'

แทนที่จะใช้รูปแบบคุณสามารถใช้f-strings ได้ :

>>> f"{Decimal('40800000000.00000000000000'):.2E}"
'4.08E+10'

3
ไวยากรณ์นี้ใช้กับสตริง f ใน 3.6+f"{Decimal('40800000000.00000000000000'):.2E}"
Tritium21

37

ระบุหมายเลขของคุณ

x = Decimal('40800000000.00000000000000')

เริ่มต้นจาก Python 3

'{:.2e}'.format(x)

เป็นวิธีที่แนะนำให้ทำ

eหมายถึงคุณต้องการสัญลักษณ์ทางวิทยาศาสตร์และ.2หมายความว่าคุณต้องการตัวเลข 2 หลักหลังจุด ดังนั้นคุณจะได้รับx.xxE±n


1
จุดของการใช้ทศนิยมคือการได้รับเลขทศนิยมทศนิยมที่แน่นอนและแม่นยำ มันไม่เทียบเท่ากับการใช้ทุ่น
asmeurer

@ asmeurer ขอบคุณสำหรับการชี้แจง เปลี่ยนคำตอบของฉัน
patapouf_ai

มีวิธีที่จะกลับจากที่นี้ไปลอย?
olenscki

@olenscki ที่กำลังทำอยู่float(x)จะแปลง x เป็นโฟลว์
patapouf_ai

33

ไม่มีใครพูดถึงวิธีการแบบสั้น ๆ.format:

ต้องการอย่างน้อย Python 3.6

f"{Decimal('40800000000.00000000000000'):.2E}"

(ฉันเชื่อว่ามันเหมือนกับ Cees Timmerman สั้นกว่านิดหน่อย)


3
ควรเป็นคำตอบที่ได้รับการยอมรับ F-สตริงเป็นอนาคตของสตริงหลามการจัดรูปแบบ :)
แกนดัล์ฟแซกซ์

1
ในฐานะที่เป็น FYI ให้กับผู้อ่านในอนาคตเหมือนตัวเอง: ถ้าคุณไม่สนใจที่จะควบคุมจำนวนของตัวเลขและไม่ทราบข้อผิดพลาดจุดลอยคุณสามารถเพียงแค่ใช้{num:E}ที่เช่น NUM = 40800000000.00000000000000
Shayaan


4

ตำแหน่งทศนิยมของฉันใหญ่เกินไป%Eดังนั้นฉันจึงต้องทำกลอนสด:

def format_decimal(x, prec=2):
    tup = x.as_tuple()
    digits = list(tup.digits[:prec + 1])
    sign = '-' if tup.sign else ''
    dec = ''.join(str(i) for i in digits[1:])
    exp = x.adjusted()
    return '{sign}{int}.{dec}e{exp}'.format(sign=sign, int=digits[0], dec=dec, exp=exp)

นี่คือตัวอย่างการใช้งาน:

>>> n = decimal.Decimal(4.3) ** 12314
>>> print format_decimal(n)
3.39e7800
>>> print '%e' % n
inf

3
เพิ่ง"{:.2e}".format(n)กลับมา'3.39e+7800'ใน Python 3.3.2 (v3.3.2: d047928ae3f6, 16 พฤษภาคม 2013, 00:06:53) [MSC v.1600 64 บิต (AMD64)] บน win32
Cees Timmerman

4

สิ่งนี้ทำงานได้ดีที่สุดสำหรับฉัน:

import decimal
'%.2E' % decimal.Decimal('40800000000.00000000000000')
# 4.08E+10

4

นี่คือรายการรวมของ"Simple"คำตอบและความคิดเห็น

PYTHON 3

from decimal import Decimal

x = '40800000000.00000000000000'
# Converted to Float
x = Decimal(x)

# ===================================== # `Dot Format`
print("{0:.2E}".format(x))
# ===================================== # `%` Format
print("%.2E" % x)
# ===================================== # `f` Format
print(f"{x:.2E}")
# =====================================
# ALL Return: 4.08E+10
print((f"{x:.2E}") == ("%.2E" % x) == ("{0:.2E}".format(x)))
# True
print(type(f"{x:.2E}") == type("%.2E" % x) == type("{0:.2E}".format(x)))
# True
# =====================================

หรือไม่มีIMPORT's

# NO IMPORT NEEDED FOR BASIC FLOATS
y = '40800000000.00000000000000'
y = float(y)

# ===================================== # `Dot Format`
print("{0:.2E}".format(y))
# ===================================== # `%` Format
print("%.2E" % y)
# ===================================== # `f` Format
print(f"{y:.2E}")
# =====================================
# ALL Return: 4.08E+10
print((f"{y:.2E}") == ("%.2E" % y) == ("{0:.2E}".format(y)))
# True
print(type(f"{y:.2E}") == type("%.2E" % y) == type("{0:.2E}".format(y)))
# True
# =====================================

เปรียบเทียบ

# =====================================
x
# Decimal('40800000000.00000000000000')
y
# 40800000000.0

type(x)
# <class 'decimal.Decimal'>
type(y)
# <class 'float'>

x == y
# True
type(x) == type(y)
# False

x
# Decimal('40800000000.00000000000000')
y
# 40800000000.0

ดังนั้นสำหรับ Python 3 คุณสามารถสลับระหว่างสามตัวนี้ได้

ชอบของฉัน:

print("{0:.2E}".format(y))

3

ฉันชอบ Python 3.x

cal = 123.4567
print(f"result {cal:.4E}")

4 ระบุจำนวนหลักที่แสดงในส่วนลอย

cal = 123.4567
totalDigitInFloatingPArt = 4
print(f"result {cal:.{totalDigitInFloatingPArt}E} ")

2

ในการแปลงทศนิยมเป็นสัญกรณ์วิทยาศาสตร์โดยไม่จำเป็นต้องระบุความแม่นยำในสตริงรูปแบบและไม่รวมศูนย์ต่อท้ายฉันกำลังใช้

def sci_str(dec):
    return ('{:.' + str(len(dec.normalize().as_tuple().digits) - 1) + 'E}').format(dec)

print( sci_str( Decimal('123.456000') ) )    # 1.23456E+2

เพื่อให้ศูนย์ต่อท้ายใด ๆ normalize()เพียงแค่ลบ


1

นี่คือสิ่งที่ง่ายที่สุดที่ฉันสามารถหาได้

format(40800000000.00000000000000, '.2E')
#'4.08E+10'

('E' ไม่คำนึงถึงขนาดตัวพิมพ์คุณสามารถใช้ '.2e' ได้ด้วย)


0
def formatE_decimal(x, prec=2):
    """ Examples:
    >>> formatE_decimal('0.1613965',10)
    '1.6139650000E-01'
    >>> formatE_decimal('0.1613965',5)
    '1.61397E-01'
    >>> formatE_decimal('0.9995',2)
    '1.00E+00'
    """
    xx=decimal.Decimal(x) if type(x)==type("") else x 
    tup = xx.as_tuple()
    xx=xx.quantize( decimal.Decimal("1E{0}".format(len(tup[1])+tup[2]-prec-1)), decimal.ROUND_HALF_UP )
    tup = xx.as_tuple()
    exp = xx.adjusted()
    sign = '-' if tup.sign else ''
    dec = ''.join(str(i) for i in tup[1][1:prec+1])   
    if prec>0:
        return '{sign}{int}.{dec}E{exp:+03d}'.format(sign=sign, int=tup[1][0], dec=dec, exp=exp)
    elif prec==0:
        return '{sign}{int}E{exp:+03d}'.format(sign=sign, int=tup[1][0], exp=exp)
    else:
        return None
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.