0

我有一个包含数十万个数字的庞大列表。该列表在由 sagemath 生成时格式错误,但我必须采用下面显示的格式将其“提供”给另一个函数。以下是格式良好的列表示例:

           C=[
           (  7.850629, 25.421135, 22.162571),
           ( 37.706629, 28.421472,  0.229876),
           ( 37.560629, 21.421809, 18.320977),
           ( 39.238629, 26.422147, 18.442572),
           ( 35.087169,  0.419785, 15.055789),
           ]

如您所见,所有元素都向右对齐,并且基于精度和小数位。所以我的问题是:如何将格式错误的列表(如下所示)转换为上面格式正确的列表

    B=[(37.074945, 22.414327,
9.756234), (37.074945, 22.414665,
1.669214), (37.074945, 22.415002,
8.571376), (37.074945, 22.41534,
1.294731), (37.074945, 22.415677,
5.753062), (37.074945, 22.416014,
7.519850)]

(如果我可以再描述一下,我会说如果我的列表被认为是一个矩阵,那么它将有成千上万的行和三列)

4

2 回答 2

0

Sage 没有内置良好的对齐功能。如果您愿意将列表视为矩阵,则可以

sage: matrix(B)
[37.0749450000000 22.4143270000000 9.75623400000000]
[37.0749450000000 22.4146650000000 1.66921400000000]
[37.0749450000000 22.4150020000000 8.57137600000000]
[37.0749450000000 22.4153400000000 1.29473100000000]
[37.0749450000000 22.4156770000000 5.75306200000000]
[37.0749450000000 22.4160140000000 7.51985000000000]

它缺少逗号和其他句法部分,但它正确对齐。如果您愿意使用 html 输出,则可以使用html.table(B). 将来(请参阅此可能的未来增强功能)应该有一个很好的“表格”功能,用于一般这样的漂亮显示器。

于 2012-07-10T12:56:19.690 回答
0

好吧,我认为这是一个普遍的 Python 问题。鉴于C您的评论,以下工作。这"%9.5f"是关键的见解:

for l in C:
    print "(%s)," % ', '.join("%9.5f"%i for i in l)
   ....:     
( 37.07494,  22.41433,   9.75623),
( 37.07494,  22.41466,   1.66921),
( 37.07494,  22.41500,   8.57138),
( 37.07494,  22.41534,  18.29473),
( 37.07494,  22.41568,   5.75306),
( 37.07494,  22.41601,  17.51985),
于 2013-12-17T13:55:01.240 回答