设置数字格式,使其与小数点对齐

2022-02-25 00:00:00 python output formatting

问题描述

在Python中,我需要格式化数字,使它们与小数点对齐,如下所示:

  4.8
 49.723
456.781
-72.18
  5
 13

是否有直接的方法可以做到这一点?


解决方案

我不认为有一种简单的方法可以做到这一点,因为在开始打印数字之前,您需要知道小数点在所有数字中的位置。(我只是看了一下卡拉米里尔的链接,以及该页面上的一些链接,但我找不到任何特别适用于此案例的链接)。

所以看起来您必须对列表中的数字进行一些基于字符串的检查和操作。例如,

def dot_aligned(seq):
    snums = [str(n) for n in seq]
    dots = [s.find('.') for s in snums]
    m = max(dots)
    return [' '*(m - d) + s for s, d in zip(snums, dots)]

nums = [4.8, 49.723, 456.781, -72.18]

for s in dot_aligned(nums):
    print(s)

输出

  4.8
 49.723
456.781
-72.18

如果要处理包含一些纯int的的float列表,则此方法会变得有点混乱。

def dot_aligned(seq):
    snums = [str(n) for n in seq]
    dots = []
    for s in snums:
        p = s.find('.')
        if p == -1:
            p = len(s)
        dots.append(p)
    m = max(dots)
    return [' '*(m - d) + s for s, d in zip(snums, dots)]

nums = [4.8, 49.723, 456.781, -72.18, 5, 13]

for s in dot_aligned(nums):
    print(s)
    

输出

  4.8
 49.723
456.781
-72.18
  5
 13

正如Mark Ransom在评论中指出的那样,我们可以使用.split

简化int的处理
def dot_aligned(seq):
    snums = [str(n) for n in seq]
    dots = [len(s.split('.', 1)[0]) for s in snums]
    m = max(dots)
    return [' '*(m - d) + s for s, d in zip(snums, dots)]

Masher在一条评论中提到,在右侧添加填充会很有用,这样就可以在对齐的列中打印数字。但是,我们不需要计算每个字符串的填充大小,我们可以使用str.ljust方法。

def dot_aligned(seq):
    snums = [str(n) for n in seq]
    dots = [len(s.split('.', 1)[0]) for s in snums]
    m = max(dots)
    left_pad = [' '*(m - d) + s for s, d in zip(snums, dots)]
    ms = max(map(len, left_pad))
    return [s.ljust(ms) for s in left_pad]

nums = [4.8, 49.723, 456.781, -72.18, 5, 13, 1.2345] * 3
cols = 4
# Get number of cells in the output grid, using ceiling division
size = len(nums) // -cols * -cols

padded = dot_aligned(nums)
for i in range(0, size, cols):
    print(*padded[i:i+cols])

输出

  4.8     49.723  456.781  -72.18  
  5       13        1.2345   4.8   
 49.723  456.781  -72.18     5     
 13        1.2345   4.8     49.723 
456.781  -72.18     5       13     
  1.2345

相关文章