我对使用python进行编程有点新意,所以请放轻松我。我正在尝试调用字符串属性rjust并指定浮点的精度。这是代码和示例输出(注意0.00右边没有对齐):
print '%s: %s %s \tchange: %.2f' % (Instance1.symbol.ljust(5),
Instance1.name.ljust(50), Instance1.buyprices.rjust(10), Instance1.val)
输出:
AXP : American Express Company 55.38 change: -1.15
AXR : Amrep Corp. 6.540 change: 0.00
答案 0 :(得分:24)
这显示了如何使用较旧的%
格式化方法使用两个小数点格式化输出的示例:
v1 = 55.39
v2 = -1.15
v3 = 6.54
v4 = 0.00
print '%8.2f %8.2f' % (v1, v2)
print '%8.2f %8.2f' % (v3, v4)
相应的输出:
55.39 -1.15
6.54 0.00
或者,您可以使用“新的和改进的”.format()功能,该功能将会存在一段时间,值得了解。以下内容将生成与上面相同的输出:
print '{:8.2f} {:8.2f}'.format(v1, v2)
print '{:8.2f} {:8.2f}'.format(v3, v4)
两组格式化指令为您的数字分配8个空格,将其格式化为小数点后2位数的浮点数。您必须调整这些值以满足您的需求。
我认为使用这种方法来格式化输出会更容易,因为.format()
将为您提供批次对输出的控制(包括校对,填充,精确)。
答案 1 :(得分:0)
没关系,我在发布问题后立即想出来......
changed to this:
def change_value(self, sym, buy, sell):
self.sym = sym
temp = float(buy) - float(sell)
self.val = "%.2f" % temp
and then called str(Instance1.val).rjust(10)